学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习
本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所偏差,在学习中如果有错会及时修改内容,也欢迎万能的朋友们批评指出,谢谢
文章第一版出自简书,如果出现图片或页面显示问题,烦请转至 简书 查看 也希望喜欢的朋友可以点赞,谢谢
componentWillMount:相当于OC中的 ViewWillAppear 方法,在组件简要被加载到视图之前调用,没有太多的功能
render:它是每个组件必需具备的方法,本质上是个函数,并且返回JSX或者其他组件来构成DOM,和Android的XML布局类似 在该函数中,只能通过this.state和this.props来访问之前在函数中初始化的数值注:只能返回一个顶级元素componentDidMount:在调用了render方法,组件加载成功并被成功渲染出来之后,所要执行的后续操作,一般都会在这个函数中进行,比如经常要面对的网络请求等加载数据操作 因为UI已经成功渲染,而且这里面是异步的,索引放在这个函数进行数据的请求等复杂的操作,不会出现UI错误this.state:开发中,组件肯定要与用户互动,React的一大创新就是将组件看成一个状态机,一开始有一个初始状态,然后用户互动,导致状态变化,从而触发重新渲染UI,举个例子
var SMZQ = React.createClass({ // 用于设置一些可变或者用来刷新界面 getInitialState(){ return{ isPositive: true, content:'5是不是负数' } }, render() { return ( <View style={styles.container}> <TouchableOpacity onPress={() => {this.dealWithState(this.state.isPositive, 5)}} > <Text>{this.state.content}</Text> </TouchableOpacity> </View> ); }, dealWithState: function (data:Boolean, num:int) { var isPositive, content; if (num > 0){ isPositive = false; content = '值不是负数'; }else { isPositive = true; content = '值是负数'; } this.setState({ isPositive: isPositive, content: content }); } });效果:
当用户点击组件,导致状态变化,this.setState方法就修改状态值,每次修改以后,会自动调用this.render方法,再次渲染组件可以把组件看成一个状态机,根据不同的status有不同的UI展示,只要使用setState改变状态值,根据diff算法算出有差值后,就会执行ReactDom的render方法,重新渲染页面注:由于this.props和this.state都用于描述组件的特性,可能会产生混淆,一个简单的区分方法就是 —— this.props表示那些一旦定义,就不再更改的特性,而this.state是会随着用户互动而产生改变的特性获取真实的DOM节点 在React Native中,组件并不是真实的DOM节点,而是存在于内存中的一种数据结构 ,叫虚拟DOM只有当它插入文档后,才会变成真实的DOM根据React的设计,所有DOM变动,都先在虚拟DOM上发生,然后再将实际发生变动的部分,反应在真实DOM上,这种算法叫做DOM diff,它可以极大提高网页的性能表现有时需要从组件获取真实DOM节点,这时就需要用到ref属性,可以看下面的示例加深理解 var SMZQ = React.createClass({ render() { return ( <View ref="mainView" style={styles.container}> <TouchableOpacity onPress={() => {this.dealWithState()}} > <Text>值</Text> </TouchableOpacity> <TextInput ref="mytextInput"></TextInput> </View> ); }, dealWithState: function () { // 让输入框获得焦点 this.refs.mytextInput.focus(); // 查看内容属性 console.log(this.refs.mainView); } });效果:
可以看出,组件View的子节点有一个文本输入框,用于获取用户的输入,这时就必须获取真实的DOM节点,虚拟DOM是拿不到用户输入的,为了做到这一点,文本输入框必须有一个ref属性,然后this.refs.refName就会返回这个真实的DOM节点需要注意的是,由于this.refs.refName属性获取的是真实DOM,所有必须等到虚拟DOM插入文档后,才能使用这个属性,否则会报错。上面代码中,通过组件指定Click事件的回调函数,确保只有等到真实DOM发生Click事件之后,才会读取this.refs.refName属性转载于:https://www.cnblogs.com/miaomiaoshen/p/6038723.html
