豆瓣app是reacnative app是什么做的吗

整理了一份React-Native学习指南 - 推酷
整理了一份React-Native学习指南
自己在学习React-Native过程中整理的一份学习指南,包含 教程、开源app和资源网站等,还在不断更新中。欢迎pull requests!
React-Native学习指南
本指南汇集React-Native各类学习资源,给大家提供便利。指南正在不断的更新,大家有好的资源欢迎Pull Requests!
同时还有Awesome React-Native系列
react-native 官方api文档
react-native 中文api文档 (翻译中)
react.js中文文档
react.js入门教程(gitbook)
react.js快速入门教程 - 阮一峰
react.js视频教程
react-native第一课
深入浅出 React Native:使用 JavaScript 构建原生应用
React Native通信机制详解
React Native布局篇
React Native 基础练习指北(一)
React Native 基础练习指北(二)
构建一个简单的列表页和2页导航
Diary of Building an iOS App with React Native
Use React Native in Existing iOS App
tcomb-form-native使用视频教程(需翻墙)
研究源码也是一个很好的学习方式
官方演示App
ReactNativeRubyChina
HackerNews-React-Native
React-Native新闻客户端
newswatch(新闻客户端)
buyscreen(购买页面)
V2EX客户端
react-native-todo
react-native-beer
react-native-stars
模仿天猫首页的app
ReactNativeChess
react native 编写的音乐软件
react-native-pokedex
CNode-React-Native
8tracks电台客户端
React-Native实现的计算器
房产搜索app
知乎专栏app
ForeignExchangeApp
react-native-snippets(代码提示)
react-native-babel(使用ES6+)
React-native官网
React-China社区
React-native组件库(比较全的组件库)
React Native Modules
11款React Native开源移动 UI 组件
谈谈 React Native - 唐巧
如何评价React-Native?
React Native概述:背景、规划和风险
扫码关注w3ctech微信公众号
已发表评论数()
请填写推刊名
描述不能大于100个字符!
权限设置: 公开
仅自己可见
正文不准确
标题不准确
排版有问题
主题不准确
没有分页内容
图片无法显示
视频无法显示
与原文不一致我们书接上文《》,继续来讲如何用 React Native 创建一个iOS APP。接下来,我们会涉及到很多控件。
AppRegistry.registerComponent(
上述是定义应用程序的入口点。这也是 Script 代码开始执行的地方。
这是一个本地用户界面反应的基本结构。我们定义的每个视图将遵循相同的基本结构。
在本教程中,我们将创建一个既可以浏览书籍又能知道书籍介绍比如作者、标题或关于书籍的简介。你还可以通过检索书名或作者来查找你想要的书籍。下面我要介绍这个应用程序。我们将会使用谷歌图书 API的数据。
添加一个标签栏
该应用程序会有一个有两项的标签栏--- Featured 和 Search。我们将首先添加它。
虽然你拥有 index.ios.js 文件中所有的代码,这是不推荐的,因为它会随着应用程序的代码的增加而混乱。为了更好的管理,我们要在不同的文件中创建类别。
创建两个 JavaScript 文件在你项目的根目录(和 index.ios.js 文件在相同的位置)。为 Search.js 文件和 Featured.js 命名。打开 Featured.js 并添加以下代码。
'use strict';
var React = require('react-native');
StyleSheet,
var styles = StyleSheet.create({
description: {
fontSize: 20,
backgroundColor: 'white'
container: {
justifyContent: 'center',
alignItems: 'center'
class Featured extends Component {
render() {
&View style={styles.container}&
&Text style={styles.description}&
Featured Tab
module.exports = F
你应该熟悉以上那个代码;它非常类似于我们之前看到的代码。我们设置 Strict Mode,加载 react-native
模块,创建视图样式,渲染UI 和渲染输出()函数功能。最后一行代码输出 Featured 类从而使他更方便地被其他文件所用。请注意我们所说的 class 和 function有点不同于 index.ios.js。JavaScript 有不同的方式表示 class和 function。可以随意选择你喜欢的你风格。接下来的教材中,我们将使用上边所使用的风格。
通过样式表中的定义,我们可以看出基本的 CSS 属性。我们为视图中的文本和中心内容设置字体大小和背景颜色。但你可能不熟悉 flex:1样式。这是 flexbox,CSS 规范的最新附加功能。flex:1 使元素标记容器占用的空间在屏幕上不被兄弟元素占用,否则它只能通过占用足够的空间来适应它的内容。以后我们将更加重视 flex。了解更多的Flexbox 样式,你可以阅读本指南。
在 Search.js 添加以下程序。
'use strict';
var React = require('react-native');
StyleSheet,
var styles = StyleSheet.create({
description: {
fontSize: 20,
backgroundColor: 'white'
container: {
justifyContent: 'center',
alignItems: 'center'
class Search extends Component {
render() {
&View style={styles.container}&
&Text style={styles.description}&
Search Tab
module.exports = S
上述程序除了文本组件中的文本都类似于 Featured.js 代码。
在 index.ios.js 中剪切所有并粘贴在下边。
'use strict';
var React = require('react-native');
var Featured = require('./Featured');
var Search = require('./Search');
AppRegistry,
TabBarIOS,
class BookSearch extends Component {
constructor(props) {
super(props);
this.state = {
selectedTab: 'featured'
render() {
&TabBarIOS selectedTab={this.state.selectedTab}&
&TabBarIOS.Item
selected={this.state.selectedTab === 'featured'}
icon={{uri:'featured'}}
onPress={() =& {
this.setState({
selectedTab: 'featured'
&Featured/&
&/TabBarIOS.Item&
&TabBarIOS.Item
selected={this.state.selectedTab === 'search'}
icon={{uri:'search'}}
onPress={() =& {
this.setState({
selectedTab: 'search'
&/TabBarIOS.Item&
&/TabBarIOS&
AppRegistry.registerComponent('BookSearch', () =& BookSearch);
这时我们需要从我们创建的文件中导出两个模块,并将他们分配给变量。在 class 内部,我们指定一个构造函数来为 class 设置一个状态。这时我们要用组件的状态函数。创建一个名为 selectedTab 的属性,并将其值设置为 featured。我们将使用 featured 来确定哪个选项卡应该是主动的。然后设置默认选项卡。
在渲染()函数中我们使用 TabBarIOS 组件创建一个标签栏。记得添加组件使用解构作业否则使用完全限定名称,例如:React.TabBarIOS。
我们创建两个标签栏项目。我们为每个项目设立选中状态并定义一个函数,当这个项目被选中时就会被命名。在 Featured 选项卡中,选择设置为 true,如果 selectTab 状态我们前边定义的值为 feature,组件 selectedTab 是否等同于「搜索」。无论哪个选项卡被设置为 true 都将是活动选项卡。我们为标签栏项目使用系统图标。
注意我们使用我们的自定义组件标签,就像任何其他组件,例如:因为我们需要相应的模块,并将其分配到一个变量,你可以使用变量引入组件文件。这导致在 render() 函数的代码组件的类包含就像是文件的一部分。顺便说一下,我为各自变量的类名使用相同名称的变量,但不一定要这样,你可以尽可能的使用你喜欢的任何名称。
当标签栏被选中后,onPress 组件的属性就会被回调函数定义。selectedTab 属性的函数集值最终确定活动选项卡。
打开模拟器并按 Command-R 重新加载应用程序,你就会看到如下显示。
接下来,我们将向应用程序添加一个导航栏,给这个项目添加两个以上的文件。他们将是根视图导航堆栈的标签。为 BookList.js 和SearchBooks.js 文件命名。
在 BookList.js 应用程序中添加以下代码。
'use strict';
var React = require('react-native');
StyleSheet,
var styles = StyleSheet.create({
class BookList extends Component {
render() {
module.exports = BookL
在 SearchBooks.js 应用程序中添加以下代码。
'use strict';
var React = require('react-native');
StyleSheet,
var styles = StyleSheet.create({
class SearchBooks extends Component {
render() {
module.exports = SearchB
在两个文件中,我们已经创建了一个带有空白视图的模块然后输出模块。
修改 Featured.js 如图:
'use strict';
var React = require('react-native');
var BookList = require('./BookList');
StyleSheet,
NavigatorIOS,
var styles = StyleSheet.create({
container: {
class Featured extends Component {
render() {
&NavigatorIOS
style={styles.container}
initialRoute={{
title: 'Featured Books',
component: BookList
module.exports = F
下一个 Search,js 修改如下所示:
'use strict';
var React = require('react-native');
var SearchBooks = require('./SearchBooks');
StyleSheet,
NavigatorIOS,
var styles = StyleSheet.create({
container: {
class Search extends Component {
render() {
&NavigatorIOS
style={styles.container}
initialRoute={{
title: 'Search Books',
component: SearchBooks
module.exports = S
就像在 Featured.js,上面创建了一个导航控制器,设置其最初的路线并为它设置标题。
重新加载应用程序,你会看到如下所示:
获取和显示数据
现在我们要读取数据了。首先我们要构建有假数据的视图,然后使用来自 API 的真数据。
在 BookList.js 文件的顶部添加如下与其他变量的声明。
var FAKE_BOOK_DATA = [
{volumeInfo: {title: 'The Catcher in the Rye', authors: "J. D. Salinger", imageLinks: {thumbnail: '/books/content?id=PCDengEACAAJ&printsec=frontcover&img=1&zoom=1&source=gbs_api'}}}
修改解构任务直到显示包含多个组件时我们才能使用。
StyleSheet,
Component,
添加以下模版:
var styles = StyleSheet.create({
container: {
flexDirection: 'row',
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
padding: 10
thumbnail: {
width: 53,
height: 81,
marginRight: 10
rightContainer: {
fontSize: 20,
marginBottom: 8
color: '#656565'
然后修改如图所示的 class:
class BookList extends Component {
render() {
var book = FAKE_BOOK_DATA[0];
&View style={styles.container}&
&Image source={{uri: book.volumeInfo.imageLinks.thumbnail}}
style={styles.thumbnail} /&
&View style={styles.rightContainer}&
&Text style={styles.title}&{book.volumeInfo.title}&/Text&
&Text style={styles.author}&{book.volumeInfo.authors}&/Text&
重新加载应用程序就会有如下显示:
在以上代码中,我们创建了一个类似于从 API 中调用的目标 JSON,我们通过这个目标为单独的一本书创建了属性和价值。在 class 文件中,我们使用假数据只为了得到第一个元素来填充我们的观点。我们使用图像组件把图像加载成视图。需要注意的是,我们要在样式表中设置它的宽度和高度。如果你不指定图像在样式表中的尺寸,它就不会出现在视图中。
我们指定一个 flexDirection 样式:“行”容器。这将使带有这种风格元素的孩子们的布局默认为水平而不是垂直。需要注意的是我们该如何包装组件内的其他组件。在上面有带有两个孩子的主要容器物----一个图像和一个视图。这个视图能显示两个属于自己的孩子----即两个文本组件。
首先是图像布局,然后视图(right Container)水平放置在它旁边。我们指定一个 flex 模版:1rightContainer。这使得视图占据了剩下的空间而不是图像。如果你想要看到 flex 样式的影响,那就添加以下 rightContainer。
backgroundColor: 'red'
重新加载应用程序,你就会看到 rightContainer 样式的组件占用的空间。它占据整个空间而不被其他兄弟姐妹所占有。它并不拉伸屏幕,因为外容器有一些填充并且图像有边缘设置权利。
从 rightContainer 删除 flex:1,重新加载应用程序。现在组件只占用足够的可以适应其内容的空间。
如果你为 flex:2 的缩略图和 rightContainer 设置一种风格,他们可能占据相同数量的空间,而且他们会有一个 2:2(或1:1)的宽度比。你可以指定任何值,所有可能的比例都会考虑在内。
你也可以尝试不同的比率得到你喜欢的样式。对于本教程,我们将从为rightContainer 添加一个红色的背景这一步继续深入。
以为度量标准进行 ,监控网络请求及网络错误,提升用户留存。访问 感受更多应用体验,想阅读更多技术文章,请访问 。推荐到广播
611529 人聚集在这个小组
(强迫症患者)
(宇智波锁柱)
第三方登录:【代码片-4】 react native 学习之模仿”探探“实现豆瓣电影app部分功能
标签: react&&&&电影&&&&豆瓣&&&&native&&&&app&&&&
'use strict'
import React, { Component } from 'react';
import { StyleSheet, Navigator } from 'react-native';
import ViewContainer from '../views/indexView';
import DetailContainer from '../views/Detail';
class AppNavigator extends Component {
_renderScene(route, navigator) {
let globalNavigatorProps = { navigator };
switch(route.ident){
case 'indexView':
&ViewContainer {...globalNavigatorProps} /&
case 'detail':
&DetailContainer {...globalNavigatorProps}
&ViewContainer {...globalNavigatorProps} /&
render() {
&Navigator initialRoute={this.props.initialRoute}
ref=&AppNavigator&
renderScene={this._renderScene}/&
module.exports = AppN
我要留言技术领域:
取消收藏确定要取消收藏吗?
删除图谱提示你保存在该图谱下的知识内容也会被删除,建议你先将内容移到其他图谱中。你确定要删除知识图谱及其内容吗?
删除节点提示无法删除该知识节点,因该节点下仍保存有相关知识内容!
删除节点提示你确定要删除该知识节点吗?推荐到广播
611529 人聚集在这个小组
第三方登录:}

我要回帖

更多关于 react native app 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信