加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

React Native 样式声明和使用

发布时间:2020-12-15 03:35:18 所属栏目:百科 来源:网络整理
导读:React Native 不实现 CSS,而是依赖于 JavaScript 来为你的应用程序设置样式。这是一个有争议的决定,你可以阅读那些幻灯片,了解背后的基本原理。 声明样式 在 React Native 中声明样式的方法如下: varstyles=StyleSheet.create({base:{width:38,height:38

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

声明样式

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

varstyles=StyleSheet.create({base:{
width:38,height:38,},background:{
backgroundColor:'#222222',active:{
borderWidth:2,borderColor:'#00ff00',});

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

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

使用样式

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

<Textstyle={styles.base}/><Viewstyle={styles.background}/>

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

<Viewstyle={[styles.base,styles.background]}/>

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

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

<View
style={[styles.base,{
width:this.state.width,height:this.state.width*this.state.aspectRatio
}]}
/>

样式传递

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

varList=React.createClass({
propTypes:{
style:View.propTypes.style,elementStyle:View.propTypes.style,render:function(){return(
<Viewstyle={this.props.style}>
{elements.map((element)=>
<Viewstyle={[styles.element,this.props.elementStyle]}/>
)}
</View>
);
}
});//...inanotherfile...<Liststyle={styles.list}elementStyle={styles.listElement}/>

属性支持

最新的 CSS 属性支持。

  • View 属性

  • Image 属性

  • Text 属性

  • Flex 属性

转载自:优聚知识共享平台

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读