react-native 入门基础介绍
一个简单的demo,用于介绍react-native相关基础信息,主要是针对有兴趣的同学参考;以下内容及代码在2018-08测试有效。
安装
- npm install -g create-react-native-app
- create-react-native-app you-app-name
- cd you-app-name
- npm start
- download Expo app:https://expo.io/(可能要注册)在手机上安装
- 扫描 npm start 后显示的二维码
为了项目顺利,请备好梯子!
这里是通过在手机上安装Expo,然后用Expo扫描启动项目后生成的二维码来预览你的react-native项目,前提是PC的IP要与手机的IP在同一个网段内。Expo打包你的项目后,每次PC端Ctrl+S都会自动更新Expo的内容。本文不介绍安装模拟器的开发方式,需要的请自行Google。
项目
主要目录结构
|—— app.js
|—— view
|—— Home.js
|—— cookbook
|—— Cookbook.js
|—— Detail.js
|—— List.js
|—— novel
|—— Novel.js
以下所有涉及组件属性请参考文章最后官网链接进行查看,本文只对关键属性作说明。
路由组件使用:react-native
UI组件使用:native-base
入口
export default createDrawerNavigator({
home: {
screen: Home
},
novel: {
screen: Novel
},
cookbook: {
screen: Cookbook
},
}, {
drawerBackgroundColor: '#ffffff',
contentOptions: {
activeTintColor: '#e91e63',
}
});
首页使用侧滑(createDrawerNavigator)路由组件,默认显示路由为对象的第一个属性值。
Home模块
export default class Home extends Component {
static navigationOptions = {
drawerLabel: 'Home',
drawerIcon: ({ tintColor }) => (
<Image
source={require('./../public/img/menu.png')}
style={[styles.icon, { tintColor: tintColor }]}
/>
),
};
render() {
return (
<View
style={{ flex: 1, marginTop: 20 }}
>
<View
style={{ flex: 1, alignItems:'center', justifyContent: 'center' }}
>
<TouchableHighlight
underlayColor={ '#fff' }
activeOpacity={ 1 }
onPress={ () => this.props.navigation.openDrawer() }>
<Image
style={{ height: 220, width: 220, borderRadius: 110 }}
source={require('./../public/img/avatar.jpg')}
/>
</TouchableHighlight>
</View>
</View>
);
}
}
该页面主要是首屏显示内容,根据页面代码注意以下三点:
- 图片链接要用TouchableHighlight
- 使用navigation.openDrawer()方法打开侧滑
- 图片地址要用require(url)方法引入
Coobook模块
const navigationConfig = {
header: null
}
export default App = createStackNavigator({
List: {
screen: List,
path: 'list/:id',
navigationOptions: (navigation) => (navigationConfig)
},
Detail: {
screen: Detail,
navigationOptions: (navigation) => ({
title: '详情'
})
},
})
cook模块功能是提供一个列表页,点击列表项进入详情页,注意以下三点:
- 用createStackNavigator路由组件实现。
- List 页面不需要顶部的header所以设置为null(具体参见文档)
- 因为详情页需要id这里可以用list/:id传参
List模块
export default class ListComponent extends Component {
render() {
return (
<View
style={{ flex: 1, paddingTop: 20 }}
>
<Container>
<Content>
<List>
<ListItem avatar onPress={() => {
this.props.navigation.navigate('Detail', {
id: 0
})
}}>
<Left>
<Thumbnail source={{ uri: 'http://xx.jpg' }} />
</Left>
<Body>
<Text>回锅肉</Text>
<Text note>一道好吃到板的菜</Text>
</Body>
<Right>
<Text note>2018-08-21</Text>
</Right>
</ListItem>
</List>
</Content>
</Container>
</View>
);
}
}
该组件用到了native-base UI组件
注意以下四点:
- 注意组件只能用提供的,style的属性也是只能用提供的。
- 顶部菜单栏高为20 ,所有宽高都不需要加单位,会自动转化为设备单位
- 文字必须要用Text包裹
- 路由跳转由navigation.navigate('name', params)实现
novel模块
export default createBottomTabNavigator({
Home: {
screen: HomeScreen,
navigationOptions: () => ({
tabBarVisible : true,
title: '蚂蚁国度',
headerBackTitle: null
}),
},
Settings: {
screen: SettingsScreen,
navigationOptions: () => ({
tabBarVisible : true,
title: '最强神级兵王',
headerBackTitle: null
}),
},
}, {
headerMode: 'screen',
});
该模块采用在底部点击菜单按钮的形式来查看不同小说,所以采用新的路由方式:
- 使用createBottomTabNavigator切换screen
- 页面内容多需要滑动,需用ScrollView组件包裹
相关参考
- RN官网:https://facebook.github.io/react-native/
- React Navigation官网: https://reactnavigation.org/
- nativeBase组件:https://nativebase.io/
若有疑问或错误,请指正,谢谢!Github blog issues
react-native 入门基础介绍的更多相关文章
- React Native 入门基础知识总结
中秋在家闲得无事,想着做点啥,后来想想,为啥不学学 react native.在学习 React Native 时, 需要对前端(HTML,CSS,JavaScript)知识有所了解.对于JS,可以看 ...
- React Native入门教程2 -- 基本组件使用及样式
在上一篇文章中,我们学会了如何搭建React Native的环境(React Native入门教程(笔记) 1 – 开发环境搭建),不知道你们是否搭建好了呢,如果还没有,那么快动起小手,来体验RN带给 ...
- React Native入门教程 3 -- Flex布局
上一篇文章中介绍了基本组件的使用 React Native入门教程(笔记) 2 – 基本组件使用及样式 本节内容将继续沿用facebook官方例子介绍如何使用Flexbox布局把界面设计的多样化. 转 ...
- React Native入门教程 1 -- 开发环境搭建
有人问我为啥很久不更新博客..我只能说在学校宿舍真的没有学习的环境..基本上在宿舍里面很颓废..不过要毕业找工作了,我要渐渐把这个心态调整过来,就从react-native第一篇博客开始.话说RN也出 ...
- React Native入门——布局实践:开发京东client首页(一)
有了一些对React Native开发的简单了解,让我们从实战出发.一起来构建一个简单的京东client. 这个client是仿照之前版本号的京东client开发的Android版应用,来源于CSDN ...
- React Native入门-刘望舒
React Native入门(一)环境搭建与Hello World React Native入门(二)Atom+Nuclide安装.配置与调试 React Native入门(三)组件的Props(属性 ...
- React Native入门——IDE及其它相关基础技术
关于React Native的开发,当中一个问题是缺少好用的IDE,有些人说不就是JS么,搞一个记事本也就写了,那样尽管牛逼,但事实上还是非常头大的,有一款好的IDE还是能提升开发效率的,这里对几个还 ...
- React Native之 ScrollView介绍和使用
前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...
- React Native 之 Touchable 介绍与使用
前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...
- react native 入门实践
上周末开始接触react native,版本为0.37,边学边看写了个demo,语法使用es6/7和jsx.准备分享一下这个过程.之前没有native开发和react的使用经验,不对之处烦请指出.希望 ...
随机推荐
- 【Mysql】索引简介
本文口味:番茄炒蛋,预计阅读:10分钟. 博客又停更了两个月,在这期间,对人生和世界多了许多思考.在人生的不同阶段,会对生活和世界有着不一样的认知,而认知的改变也会直接反应在行为模式之中. 对于生活的 ...
- curl请求的get.post.put.delete对接其他系统接口方法
class HttpCurl{ //控客云平台的appid private $appId = xxxxxx; //控客云平台的appkey private $appKey = 'xxxxxxxxxxx ...
- MySql中的SHOW INDEX 查出的结果列代表的意义
MySQL SHOW INDEX语法的实际操作用法以及其实际查看索引状态(语法)的具体内容的描述,如果你对这一技术,心存好奇的话,以下的文章将会揭开它的神秘面纱. INDEX FROM tbl_nam ...
- 【朝花夕拾】Android自定义View篇之(十)TouchSlop及VelocityTracker
前言 在Android事件中,有几个比较基本的概念和知识点需要掌握.比如,表示最小移动阈值的TouchSlop,追踪事件速度的VelocityTracker,用于检测手势的GestureDetecto ...
- Java底层技术系列文章-总揽
对于工作中经常用到的东西,还是多看看实现原理,这样用着才能放心. 源码思想学习计划: 1.java基础库 HashCode深入理解 java线程框架窥探 2.集合类 java枚举类使用 递归 ...
- 彻底搞清楚c#中的委托和事件
一.什么是委托呢? 听着名字挺抽象,确实不好理解.面试官最喜欢考察这个,而且更喜欢问:“委托和事件有何异同?”.如果对一些知识点没有想明白,那么很容易被绕进去.研究任何事物,我们不妨从它的定义开始,委 ...
- 20131214-HTML基础-第二十一天
[1]表单练习 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www ...
- Shell文件
#!/bin/bashecho "======================欢迎来到进爷故事会======================="echo "******* ...
- 【题解】Unit Fraction Partition-C++
Description给出数字P,Q,A,N,代表将分数P/Q分解成至多N个分数之和,这些分数的分子全为1,且分母的乘积不超过A.例如当输入数据为2 3 120 3时,我们可以得到以下几种分法: In ...
- 2017-10271weblogic漏洞exp测试及补丁测试
靶机:weblogic12.1.3.0 战斗机:kali 导弹:burpsuite 1.首先开启kali某端口监听 2.向靶机发送exp 3.查看kali监听 打码保平安~~ 4.打上补丁 5.验证补 ...