React Native之样式

前端之家收集整理的这篇文章主要介绍了React Native之样式前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

样式

React Native 不实现 CSS,而是依赖于 JavaScript 来为你的应用程序设置样式。这是一个有争议的决定,你可以阅读那些幻灯片,了解背后的基本原理。

声明样式

在 React Native 中声明样式的方法如下:

  1. var styles = StyleSheet.create({
  2. base: {
  3. width: 38,height: 38,},background: {
  4. backgroundColor: '#222222',active: {
  5. borderWidth: 2,borderColor: '#00ff00',});

StyleSheet.create的创建是可选的,但提供了一些关键优势。它通过将它们转换为引用一个内部表的纯数字,来确保值是不可变的不透明的。通过将它放在文件的最后,也确保了它们为应用程序只创建一次,而不是每一个 render 都创建。

所有的属性名称和值是工作在网络中的一个子集。对于布局来说,React Native实现了Flexbox

使用样式

所有的核心组件接受样式属性

  1. <Text style={styles.base} />
  2. <View style={styles.background} />

它们也接受一系列的样式。

  1. <View style={[styles.base,styles.background]} />

行为与Object.assign相同:在冲突值的情况下,从最右边元素的值将会优先,并且 falsy 值如falseundefinednull将被忽略。一个常见的模式是基于某些条件有条件地添加一个样式。

  1. 最后,如果真的需要,您还可以在render中创建样式对象,但是这种做法非常不赞成。最后把它们放在数组定义中。

  2. <View
  3.   style={[styles.base,{
  4.     width: this.state.width,height: this.state.width * this.state.aspectRatio
  5.   }]}
  6. />
  7. 样式传递

  8. 为了让一个 call site 定制你的子组件的样式,你可以通过样式传递。使用View.propTypes.styleText.propTypes.style,以确保只有样式被传递了。

  9. var List = React.createClass({
  10.   propTypes: {
  11.     style: View.propTypes.style,elementStyle: View.propTypes.style,render: function() {
  12.     return (
  13.       <View style={this.props.style}>
  14.         {elements.map((element) =>
  15.           <View style={[styles.element,this.props.elementStyle]} />
  16.         )}
  17.       </View>
  18.     );
  19.   }
  20. });
  21. // ... in another file ...
  22. <List style={styles.list} elementStyle={styles.listElement} />

猜你在找的React相关文章