React Native开发(二)
Props (属性)与State(状态)Props 可以看做是android中的 final static 成员变量 import React,{ Component } from 'react';
import { AppRegistry,Image } from 'react-native';
class Bananas extends Component { render() { let pic = { uri: 'https://upload.wikimedia.org/wikipedia/commons/d/de/Bananavarieties.jpg'
};
return (
<Image source={pic} style={{width: 193,height: 110}} />
);
}
}
AppRegistry.registerComponent('Bananas',() => Bananas);
上面是个简单的例子,image定义的View,source和stype都是js中的属性,具体的值是通过props获取的 import React,Text,View } from 'react-native';
class Greeting extends Component { render() { return ( <Text>Hello {this.props.name}!</Text> ); } } class LotsOfGreetings extends Component { render() { return ( <View style={{alignItems: 'center'}}> <Greeting name='Rexxar' /> <Greeting name='Jaina' /> <Greeting name='Valeera' /> </View> ); } } AppRegistry.registerComponent('LotsOfGreetings',() => LotsOfGreetings);
从这个例子里面可以看出执行顺序是从LotsOfGreetings开始执行的 分解成java代码 class LotsOfGreetings extends Component { main(){ new Greeting (Rexxar); new Greeting (Jaina); new Greeting (Valeera); } } class Greeting { private final String name; Greeting (String name){ this.name = name; } main(){ system.out(this.name); } }
大概这个意思,语法问题就算了,看逻辑就行 props是在父组件中指定,而且一经指定,在被指定的组件的生命周期中则不再改变。 对于需要改变的数据,我们需要使用state。 看一下例子: import React,View } from 'react-native';
class Blink extends Component { constructor(props) { super(props); this.state = { showText: true };
// 每1000毫秒对showText状态做一次取反操作
setInterval(() => {
this.setState({ showText: !this.state.showText });
},1000);
}
render() {
// 根据当前showText的值决定是否显示text内容
let display = this.state.showText ? this.props.text : ' ';
return (
<Text>{display}</Text>
);
}
}
class BlinkApp extends Component { render() { return ( <View> <Blink text='I love to blink' /> <Blink text='Yes blinking is so great' /> <Blink text='Why did they ever take this out of HTML' /> <Blink text='Look at me look at me look at me' /> </View> ); } } AppRegistry.registerComponent('BlinkApp',() => BlinkApp);
看了之前的例子在来分析这个例子,就比较好弄清楚了 在Blink的render() 里面使用this.props 来获取test的值,区别就是多了个显示与隐藏的变化 上面的都是一些基本的使用,下一章看一下样式的设置 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |