版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、react native 实战系列教程之完成首页首页功能前面,我们已经完成了影视信息组件的开发,接下来,我们要用该组件来完成首页界面功能的开发,如下图可以看到,首页顶部一个标题栏,下面是最新、最热两个选项卡。我们要完成的有标题栏、选项卡、以及选项卡切换的内容。标题栏这里的标题栏,我们使用的是ToolbarAndroid,看名称我们就知道这个是Android下特有的组件view,所以就立马想到,这个组件是iOS、android不能通用的。因此,我们定义一个TitleBarComponent,方便以后重复使用和ios适配。这里,先提一下关于组件适配的一些问题。组件平台适配不同平台使用不同的组件,R
2、eact Native 提供了以下四种解决方案最直接的方案就是把组件放置到不同的文件夹下:/common/components/ /android/components/ /ios/components/根据平台不同在组件的文件命名上加以区分,如下:BigButtonIOS.jsBigButtonAndroid.js使用扩展名BigButton.ios.jsBigButton.android.js以上三种方案,再引用的时候去掉平台标识,如下import BigButton from ./components/BigButton;Platform.select()import React, Co
3、mponent,Platform from react;var Component = Platform.select( ios: () = require(ComponentIOS), android: () = require(ComponentAndroid),);Platform.OS在iOS上会返回ios,而在Android设备或模拟器上则会返回android。创建标题栏根据上面的方案,我们这里使用的是使用扩展名的方案来适配平台的。在js/component下创建TitleBarComponent.android.js文件。标题栏总共有标题、副标题和左边的返回按钮icon,返回按钮只
4、有在子页面(二级页面)才有,因此我们定义如下属性/初始化propsstatic defaultProps = title:,/标题 subtitle:,/副标题 subScene:true,/是否是子页面;然后,在render返回一个ToolbarAndroidrender() return( ); /返回按钮事件 _onIconClick() 这里几个属性说明下title 就是标题titleColor 设置标题颜色subtitle 就是副标题subtitleColor 设置副标题颜色actions 了解android的都知道Toolbar右边还可以设置一些动作按钮(我们这里没有就不设置该属性
5、)它的格式如下,可以设置多个const actions = title:全部,show:always,icon:require(././img/icon_all.png),showWithText:true,onActionSelected 动作按钮被触发时的回调(我们这里没有就不设置该属性)onIconClicked 标题栏左边的图标被点击后的回调(我们这里是返回按钮,返回图标可以到github上得到)style 设置整个标题栏的样式,高度、背景等。TitleBarComponent的完整代码如下import React,Component from react;import Toolbar
6、Android, DeviceEventEmitter, StyleSheet, Text, TouchableOpacity,from react-native;export default class TitleBarComponent extends Component constructor(props) super(props); /初始化props static defaultProps = title:,/标题 subtitle:,/副标题 subScene:true,/是否是子页面 ; render() return( ); /返回按钮事件 _onIconClick() con
7、st styles = StyleSheet.create( toolbar: height:56, backgroundColor:#ff5722, ,);这样我们就完成了标题栏的设计。创建首页Scene添加标题接下来我们需要创建一个首页Scene,来展示首页功能。在js文件夹新建HomeScene.js文件,并为首页添加一个标题栏。import React,Component from react;import View, Text, StyleSheet, TouchableOpacity from react-native;import TitleBar from ./componen
8、t/TitleBarComponentexport default class HomeScene extends Component constructor(props) super(props); render() return( ); ;然后将index.android.js使用HomeSceneimport HomeScene from ./js/HomeScene;class XiFan extends Component render() return( ); AppRegistry.registerComponent(XiFan, () = XiFan);添加选项卡这样首页的标题
9、有了,我们接下来要添加最新、最热两个选项卡在HomeScene内添加如下代码state增加一个tabIndex属性,标识当前选中的tab项constructor(props) super(props); this.state = tabIndex:0, ;接着就是绘制Tab了/tab切换_onTabPress(index) this.setState( tabIndex:index, );render() return( 最新 最热 );该段代码的核心主要是根据tabIndex是否被选中项,动态修改View的样式var styles = StyleSheet.create( TabSelect
10、: flex:1, textAlign:center, color:white, , TabUnderlineSelect: backgroundColor:white, height:2, , TabUnSelect: flex:1, textAlign:center, color:#d5d5d5, , TabUnderlineUnSelect: height:0, ,);添加选项卡内容应用的功能就是像在堆积木一样,一点一点叠起来。现在给选项卡下方添加对应的内容。选项卡切换时,底下切换到对应的内容,我们这里使用的是ViewPagerAndroid。/ViewPager 页面发生切换时调用,修
11、改tabIndex_onPageSelected(event) const position = event.nativeEvent.position; this.setState( tabIndex:position, );_onPageScrollStateChanged(status) /idle 空闲,意味着当前没有交互。 /dragging 拖动中,意味着当前页面正在被拖动。 /settling 处理中,意味着当前页面发生过交互,且正在结束开头或收尾的动画。render() return( ./省略其它代码 this.viewPager = viewPager );主要说几个属性in
12、itialPage 初始显示哪个页面onPageSelected页面选中时的回调函数onPageScrollStateChanged 滚动状态发生变化时调用(目前没用到)ref 定义该组件的实例对象,这里我们将ViewPagerAndroid实例对象声明为viewPager,然后我们就可以在这个页面内使用该对象,比如,前面的_onTabPress方法,在tab切换时需要下面的内容也切换到对应的内容,所以我们对_onTabPress方法添加如下代码:/tab切换_onTabPress(index) this.viewPager.setPage(index); this.setState( tab
13、Index:index, );调用了viewPager对象setPage方法,进行页面切换。还有另一种定义ref方式,如下: ./省略其它代码然后使用对象时/tab切换_onTabPress(index) this.refs.viewPage.setPage(index); this.setState( tabIndex:index, );再看下上面的代码,我们在ViewPagerAndroid内部塞了两个View,这两个View实际上就是要显示的内容了,它们就是我们之前自定义的DramaComponent,传入了不同的url,一个是最新的地址,一个是最热的人气,这样解析显示出来就是对应的数据
14、了。关于ViewPagerAndroid更多信息,可以查看ViewPagerAndroid最后上一下本节的完成的成果效果图:HomeScene.js的所有代码import React,Component from react;import View, Text, StyleSheet, TouchableOpacity, ViewPagerAndroid from react-native;import TitleBar from ./component/TitleBarComponentimport DramaComponent from ./component/DramaComponent
15、;export default class HomeScene extends Component constructor(props) super(props); this.state = tabIndex:0, ; /tab切换 _onTabPress(index) this.viewPager.setPage(index); this.setState( tabIndex:index, ); /ViewPager 页面发生切换时调用 _onPageSelected(event) const position = event.nativeEvent.position; this.setSt
16、ate( tabIndex:position, ); _onPageScrollStateChanged(status) /idle 空闲,意味着当前没有交互。 /dragging 拖动中,意味着当前页面正在被拖动。 /settling 处理中,意味着当前页面发生过交互,且正在结束开头或收尾的动画。 render() return( 最新 最热 this.viewPager = viewPager ); ;var styles = StyleSheet.create( TabSelect: flex:1, textAlign:center, color:white, , TabUnderlineSelect: backgroundColor
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 考古遗址桥梁保护协议
- 债权转为股权投资协议
- 2025版电子商务供应链金融合作协议3篇
- 高铁建设机械费施工合同
- 联营合作项目管理误区
- 运输企业社会责任与可持续发展
- 临时娱乐市场建设合同
- 雕塑艺术任课教师聘用合同
- 宠物行业经纪人招聘协议
- 招投标项目环境保护要求
- 穿越河流工程定向钻专项施工方案
- 地球物理学进展投稿须知
- 机床精度检验标准 VDI3441 a ISO230-2
- 社会主义新农村建设建筑废料利用探究
- 解析电力施工项目的信息化管理
- 火炬介绍 音速火炬等
- 制剂申请书(共16页)
- 《质量守恒定律》评课稿
- 人教版七年级上册地理《第4章居民与聚落 第3节人类的聚居地——聚落》课件
- 对县委常委班子及成员批评意见范文
- 数据中心IDC项目建议书
评论
0/150
提交评论