从零学React Native之11 TextInput

TextInput 组件是用来通过键盘输入文字,可以使用View组件和Text组件样式,没有自己特定的样式。
与Text组件类似,TextInput组件内部的元素不再使用FlexBox布局,而采用文本布局。详情见上一篇文章从零学React Native之10Text

TextInput属性

只列出了一些常用的,详情见官网

| 属性名 | 描述 |
| :------------- :|:-------------:|
| defaultValue | 字符类型,定义TextInput组件中的字符串默认值 |
| autoCorrect | 布尔类型,是否自动更正用户输入,默认是true |
| autoFocus | 是否自动获取焦点,默认为false|
| editable | 布尔类型,是否允许修改组件内字符,false代表不能修改 |
| keyboardType | 字符串类型,取值包括'default', 'email-address', 'numeric', 'phone-pad', ( 'ascii-capable', 'numbers-and-punctuation', 'url', 'number-pad', 'name-phone-pad', 'decimal-pad', 'twitter', 'web-search')括号里的只支持ios平台 |
| MaxLength | 数值类型,定义TextInput最多允许用户输入多少个字符 |
| multiline | 布尔类型,是否允许多行显示,默认值false|
| placeholder | TextInput无文字的时候显示的提示内容 |
| placeholderTextColor | placeholder文字颜色,建议不用修改 |
| secureTextEntry | 布尔类型 true按照密码样式显示,默认是false |
| value | 字符串类型,设置TextInput里面的值,目前有可能带来屏幕闪烁,可以用defaultValue临时代替|
| onSubmitEditing | 用户点击提交键的时候调用,如果允许多行显示,该属性失效 |
| onContentSizeChange | 内容长度发生变化的时候,只会在多行显示的时候生效 |
| onChangeText | 内容长度发生变化的时候调用 |

0.34版本, Android端添加了controlled selection属性
详情:
Add TextInput controlled selection prop on Android (<tt>3c1b69c</tt>) - @janicduplessis

下面的例子

class UselessTextInput extends Component {
  constructor(props) {
    super(props);
    this.state = { text: 'Useless Placeholder' };
  }

  render() {
    return (
      <TextInput
        style={{marginTop:100,height: 40, borderColor: 'gray', borderWidth: 1}}
        onChangeText={(text) => this.setState({text})}
        value={this.state.text}
      />
    );
  }
}

// App registration and rendering
AppRegistry.registerComponent('AwesomeProject', () => UselessTextInput);
ios运行结果
Android运行结果

两个平台不同表现

对比发现 Android端 borderWidth是不生效的,默认有一个输入的线,符合Android设计,Android字体默认很小,我们把上面样式中的height换成fontSize,来看下

 <TextInput
      style={{marginTop:100,fontSize: 40, borderColor:'gray',borderWidth: 1}}
      onChangeText={(text) => this.setState({text})}
      value={this.state.text}
/>

可以看到Android端字体变大了,但是IOS端没有了

左面是IOS右面Android

IOS平台上,没有指定height,TextInput组件不会显示。
一般情况下,我们需要指定FontSize和height,当上下padding为0的时候,height至少是FontSize的1.1倍时Android端才能保证字体完全显示。而默认Android端是有padding的。
如下面的代码可以基本适配两个平台:

render() {
    return (
       <TextInput
            style={{marginTop:100,fontSize: 30,height:43, 
            borderColor: 'gray', borderWidth: 1,
            paddingBottom:5,paddingTop:5}}
            onChangeText={(text) => this.setState({text})}
            value={this.state.text}
          />
        );
    }```
##TextInput组件的生命周期和回调方法
1. 当用户点击输入框时,onFocus调用,获取焦点
2. 当用户输入的时候onChangeText和onChange回调,一般使用onChangeText,里面参数为输入的文本
3. 当用户按下提交键,onSubmitEditing回调,多行没有提交键
4. 当组件失去焦点,onEndEditing或onBlur调用,一般情况用onEndEditing就足够了

注意:当点击点击另一个TextInput组件时会触发失去焦点事件,**在单行的输入框中按下提交键,Android端不触发失去焦点事件。**

最方便的操作就在onChangeText事件中时刻获取用户输入的内容


更多精彩请关注微信公众账号likeDev
![likeDev.jpg](http://upload-images.jianshu.io/upload_images/1132780-8055315c103d2753.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容