React-Native进阶_7.TextInput的使用实现搜索功能
前面使用TabBar 实现了底部tab标签,通过stackNavigator 实现了页面跳转,接下来,使用TextInput 来实现一个搜索功能。
TextInput 属性比较多,不一一介绍,具体可以百度搜索或者结合源码。
下面介绍介个比较常用的属性
<TextInput style={{height:50}} placeholder ="搜索 ..."// = android EditText hint placeholderTextColor="#6435c9"// = hint color underlineColorAndroid='transparent'// 下划线透明 // clearButtonMode="while-editing" onChangeText={(query) =>{ this.setState({ query:query, loaded:false, });// 当内容改变时执行该方法 }} onSubmitEditing={this.fetchData.bind(this)} //secureTextEntry // onFocus={() =>console.log('onFocus')} //选中文本框 // onBlur={() =>console.log('onBlur')}//离开文本框 // onChange={() =>console.log('onChange')}//文本框内容变化 // onChangeText={(text) =>console.log(text)}//文本框内容变化,变化的内容 // onEndEditing={() =>console.log('onEndEditing')}//文本框编译结束 // onSubmitEditing={() =>console.log('onSubmitEditing')}//按下回车键 // autoFocus // defaultValue="火星救援" // autoCorrect={false} //editable={false} //keyboardType='url' web-search />
实现思路跟前面两个页面一样,集合TabBar 在主页面,添加第三个底部tab标签 搜索标签,搜索页面使用TextInput 实现输入框功能
输入框中输入能容点击回车 跳转到搜索结果列表页,由前面的 stackNavigator 实现 ,点击列表页,跳转到详情页,也是由stackNavigator实现。
const App = StackNavigator({ Main: {screen: SearchForm, navigationOptions: { title: "搜索", headerLeft: null, headerStyle:{ elevation: 0 }, headerTitleStyle:{ alignSelf:'center'}, },}, //搜索结果列表 SearchResult: {screen: SearchResult, navigationOptions:({navigation,screenProps}) =>({ headerTitle: navigation.state.params.title, } ) }, //详情页 Detail: {screen: MovieDetail, navigationOptions:({navigation,screenProps}) =>({ headerTitle: navigation.state.params.info, } ) }, });
展示UI跟前面的列表相同由ListView 实现。
render() { return ( <View style={styles.Container}> <TabNavigator> <TabNavigator.Item selected={this.state.selectedTab === 'home'} title="推荐电影" renderIcon={() => <Image source={TAB_NORMAL_1} style={styles.icon}/>} renderSelectedIcon={() => <Image source={TAB_PRESS_1} style={styles.icon}/>} badgeText="1" onPress={() => this.setState({selectedTab: 'home'})}> <Feature/> </TabNavigator.Item> <TabNavigator.Item selected={this.state.selectedTab === 'profile'} title="北美票房" renderIcon={() => <Image source={TAB_NORMAL_2} style={styles.icon}/>} renderSelectedIcon={() => <Image source={TAB_PRESS_2} style={styles.icon}/>} onPress={() => this.setState({selectedTab: 'profile'})}> <USBox/> </TabNavigator.Item> <TabNavigator.Item renderIcon={() => <Image source={{uri:icons.search}} style={styles.icon}/>} selected={this.state.selectedTab === 'search'} title="搜索" onPress={() => this.setState({selectedTab: 'search'})}> <Search/> </TabNavigator.Item> </TabNavigator> </View> ); }
UI效果展示:
React-Native进阶_7.TextInput的使用实现搜索功能的更多相关文章
- React Native 组件之TextInput
React Native 组件之TextInput类似于iOS中的UITextView或者UITextField,是作为一个文字输入的组件,下面的TextInput的用法和相关属性. /** * Sa ...
- 从零学React Native之11 TextInput
TextInput 组件是用来通过键盘输入文字,可以使用View组件和Text组件样式,没有自己特定的样式. 与Text组件类似,TextInput组件内部的元素不再使用FlexBox布局,而采用文本 ...
- react native进阶
一.前沿||潜心修心,学无止尽.生活如此,coding亦然.本人鸟窝,一只正在求职的鸟.联系我可以直接微信:jkxx123321 二.项目总结 **||**文章参考资料:1. http://blog ...
- React Native 接入微博、微信、QQ 登录功能
在 App 开发中我们经常需要在用户登录模块接入 SNS 登录组件,这样会大大提高用户的注册体验.特别当一个不是刚性需求 App 推广的时候,这样会很大的降低用户体验的成本,没有人愿意忍受输入邮箱.手 ...
- 教你轻松在React Native中集成统计(umeng)的功能(最新版)
关于在react-native中快速集成umeng统计,网上的文章或者教程基本来自----贾鹏辉老师的文章http://www.devio.org/2017/09/03/React-Native-In ...
- React Native随笔——组件TextInput
一.实例 先看一下我要做的搜索框的样子 需要一个Image,和一个TextInput 去掉默认下划线 underlineColorAndroid='transparent' 设置光标颜色 select ...
- (转)React Native 使用react-native-image-picker库实现图片上传功能
react-native-image-picker作为一个集成相机和相册的功能的第三方库,因为其使用相对简单受到前端开发人员的喜爱. react-native-image-picker使用 首先,安装 ...
- [React Native]高度自增长的TextInput组件
之前我们学习了从零学React Native之11 TextInput了解了TextInput相关的属性. 在开发中,我们有时候有这样的需求, 希望输入区域的高度随着输入内容的长度而增长, 如下: 这 ...
- React Native 学习笔记--进阶(二)--动画
React Native 进阶(二)–动画 动画 流畅.有意义的动画对于移动应用用户体验来说是非常必要的.我们可以联合使用两个互补的系统:用于全局的布局动画LayoutAnimation,和用于创建更 ...
随机推荐
- saltstack实现自动化扩容
案例:当nginx的并发达到3000,并持续了一段时间时,通过自动化创建一台虚拟机,部署应用最后添加到集群提供服务: zabbix监控(nginx并发量)------->action------ ...
- 《Java 程序设计》团队博客第十一周(第一次)
<Java 程序设计>团队博客第十一周(第一次) 团队项目 1.项目内容.目标 项目内容 本组的团队项目准备实现一个有关于大富翁有的游戏程序. 大富翁游戏,以经营权为主要的游戏方式,通过购 ...
- Jquery3 常规选择器
学习要点: 1.简单选择器 2.进阶选择器 3.高级选择器 jQuery 最核心的组成部分就是:选择器引擎.它继承了 CSS 的语法,可以对 DOM 元素的标签名.属性名.状态等进行快速准确的选择,并 ...
- 重新想,重新看——CSS3变形,过渡与动画③
这一篇主要谈谈CSS3的过渡属性. 过渡属性被设计的十分通俗易懂,属性写法为transition,有四个子属性: <transition-property> 表示需要过渡的属性[必须](本 ...
- Python-自省机制
help 如果说能够通过一个函数就能够学会 Python,那这个函数一定就是 Python 提供的第一 个自带说明 help().help 函数的作用就是查看对象的帮组文档.比如: >> ...
- JDK 中的监控与故障处理工具-03 (jstat)
jstat : JVM statistics monitoring tool jstat 命令可以监控 JVM 虚拟机各种运行时状态信息, 包括 内存状态 ,垃圾回收 ,类的装载等信息. jstat ...
- 51 Nod 1091 线段的重叠
2017-09-24 19:51:41 writer:pprp 上一个题目就是关于线段重叠最大值,这个是找区间最长重合? 给你n个线段,然后让你在其中选择两条,使两条尽可能重合多一点 解决方法; 1. ...
- 使用阿里云ECS安装HDFS的小问题
毕设涉及HDFS,理论看的感觉差不多了,想搭起来测试一下性能来验证以便进行开题报告,万万没想到装HDFS花费了许多天,踩了许多坑,记录一下. 背景:使用两台阿里云学生机ECS,分处不同账号不同区域,一 ...
- 在 Spark 中使用 IPython Notebook
本文是从 IPython Notebook 转化而来,效果没有本来那么好. 主要为体验 IPython Notebook.至于题目,改成<在 IPython Notebook 中使用 Spark ...
- Postman的安装
打开chrome->设置->扩展程序->获取更多扩张程序:输入 postman就可以安装了 可能需要蓝灯FQ 安装好了直接打开即可使用