Andriod React Native 样式表中可用样式属性

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

写了这么多篇Android React Native的博文,基本上把复杂的东西都搞定了,接下来来看看一些轻松的东西,和布局有关,就是css样式,那么一个View可以设置哪些css样式呢,是和web中的css样式完全一样呢,还是有所不同呢?其实你只要在样式表中书写一个不存在的样式,就会报一大堆错,提示你该样式不存在,然后提供所有可用的样式给你,如图

下面的样式就是样式表中所有可用的属性

"alignItems","alignSelf","backfaceVisibility","backgroundColor","borderBottomColor","borderBottomLeftRadius","borderBottomRightRadius","borderBottomWidth","borderColor","borderLeftColor","borderLeftWidth","borderRadius","borderRightColor","borderRightWidth","borderStyle","borderTopColor","borderTopLeftRadius","borderTopRightRadius","borderTopWidth","borderWidth","bottom","color","flex","flexDirection","flexWrap","fontFamily","fontSize","fontStyle","fontWeight","height","justifyContent","left","letterSpacing","lineHeight","margin","marginBottom","marginHorizontal","marginLeft","marginRight","marginTop","marginVertical","opacity","overflow","padding","paddingBottom","paddingHorizontal","paddingLeft","paddingRight","paddingTop","paddingVertical","position","resizeMode","right","rotation","scaleX","scaleY","shadowColor","shadowOffset","shadowOpacity","shadowRadius","textAlign","textDecorationColor","textDecorationLine","textDecorationStyle","tintColor","top","transform","transformMatrix","translateX","translateY","width","writingDirection"

接下来我们来一一解释一下。不过在这之前,我们还需要解释一下再React中,样式表的几种使用方法

样式的声明

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

使用样式

<@H_502_188@Text style={styles.base} />
<@H_502_188@View style={styles.background} />

也可以接收一个数组

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

也可以根据条件来应用样式

4047d14" data-snippet-saved="false" data-codota-status="done"><View style={[styles.base,this.state.active && styles.active]} />

假如this.state.active是true,styles.active就会被应用,如果为false,styles.active就不会被应用。

当然也是支持下面的这种写法

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

接下来来讲讲样式表中的具体属性

定位

定位分为相对定位和绝对定位,属性名为position属性值为absoluterelative

当使用绝对布局时,定位根据屏幕来进行。

var AwesomeProject = React.createClass({
  render: function() {
    return (
    <View style={styles.container}>
        <View style={styles.Box1}/>
        <View style={styles.Box2}/>
        <View style={styles.Box3}/>
        <View style={styles.Box4}/>
   </View>
    );
  },});

var styles = StyleSheet.create({
  container:{
    flex:1,backgroundColor:'#ff0'//黄色
  },Box1:{
    width:50,height:50,backgroundColor:'#f00',//红色
    position :'absolute',left:30,//左边距离屏幕左侧30单位
  },Box2:{
    width:50,backgroundColor:'#0f0',//绿色
    position :'absolute',top:30,//上边距离屏幕上侧30单位
  },Box3:{
    width:50,backgroundColor:'#f0f',//紫色
    position :'absolute',right:30,//右边距离屏幕右侧30单位
  },Box4:{
    width:50,backgroundColor:'#00f',//蓝色
    position :'absolute',bottom:30//下边距离屏幕下侧30单位
  }
});

效果图如下。

当对应的值为负数时,方向与原方向相反,即如果top为-50,则会整个移出到屏幕外(向上移到50个单位)。

那么相对布局又是怎么样的呢

var AwesomeProject = React.createClass({

  render: function() {
    return (
    <View style={styles.container}>
        <View style={styles.Box1}/>
   </View>
    );
  },//红色
    position :'relative',});

效果

可以看到设置了top和left后,相对于不使用定位的位置向右向下移动了30单位,如果值为负数,也是往相反的方向移到。

但是如果设置了right和bottom后,又会怎么样呢

var styles = StyleSheet.create({
  container:{
    flex:1,bottom:30,});

其实它的效果就是对应的top和left为负值的情况。距离原来位置的右侧30单位,距离原来位置下侧30单位,即向上向左平移30单位。原来位置就是不使用定位时的位置。如图

默认情况下使用的是相对定位

边框宽度

borderBottomWidth //底部边框宽度
borderLeftWidth  //左边边框宽度
borderRightWidth //右边边框宽度
borderTopWidth //顶部边框宽度
borderWidth  //所有边框宽度

你可以使用设置所有边框的宽度,也可以设置指定某条边的宽度。

边框颜色

同边框宽度属性属性值为字符串类型的rgb表示方式

borderBottomColor
borderLeftColor
borderRightColor
borderTopColor
borderColor

外边距

marginBottom
marginLeft
marginRight
marginTop
marginVertical
marginHorizontal
margin

值得注意的是marginVertical相当于同时设置marginTop和marginBottom,marginHorizontal相当于同时设置marginLeft和marginRight,margin相当于同时设置四个

内边距

paddingBottom  
paddingLeft  
paddingRight  
paddingTop  
paddingVertical
paddingHorizontal  
padding

背景色

背景色,属性值为字符串类型的rgb表示方式

backgroundColor

边框圆角

borderTopLeftRadius
borderTopRightRadius
borderBottomLeftRadius
borderBottomRightRadius
borderRadius

宽高

width 
height

Flex布局相关

相关内容Flex 布局教程:语法篇Flex 布局教程:实例篇,个人觉得写得很清晰

flex number 
flexDirection enum('row','column') 
flexWrap enum('wrap','nowrap') 
alignItems enum('flex-start','flex-end','center','stretch') 
alignSelf enum('auto','flex-start','stretch') 
justifyContent enum('flex-start','space-between','space-around')

字体相关属性

color 字体颜色
fontFamily 字体族
fontSize 字体大小
fontStyle 字体样式,正常,倾斜等,值为enum('normal','italic')
fontWeight 字体粗细,值为enum("normal",'bold','100','200','300','400','500','600','700','800','900')
letterSpacing 字符间隔
lineHeight 行高
textAlign 字体对齐方式,值为enum("auto",'left','right','justify')
textDecorationLine 貌似没效果,字体修饰,上划线,下划线,删除线,无修饰,值为enum("none",'underline','line-through','underline line-through')
textDecorationStyle enum("solid",'double','dotted','dashed') 貌似没效果,修饰的线的类型
textDecorationColor 貌似没效果,修饰的线的颜色
writingDirection enum("auto",'ltr','rtl') 不知道什么属性,写作方向?从左到右?从右到左?

图片相关属性

resizeMode enum('cover','contain','stretch')
overflow enum('visible','hidden') 超出部分是否显示hidden为隐藏
tintColor 着色,rgb字符串类型
opacity 透明度

其中resizeMode 中的三个属性,contain是指无论如何图片都包含在指定区域内,假设设置的宽度高度比图片大,则图片居中显示,否则,图片等比缩小显示

测试代码如下

 var AwesomeProject = React.createClass({ render: function() { return ( <@H_502_188@View style={styles.container}> <@H_502_188@Image source={{uri:'https://ss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/img/logo/bd_logo1_31bdc765.png'}} style={styles.img}></@H_502_188@Image> </@H_502_188@View> ); },}); var styles = StyleSheet.create({ container:{ backgroundColor:'#ff0'//黄色 },img:{ flex:1,height:150,resizeMode:"contain" },}); 

效果图如下图显示

将高度改成50,则进行缩小

cover是指按实际大小进行显示,超出部分进行裁剪,将属性值改成cover之后的效果图如下

stretch是指将图像进行拉伸显示,将属性值改为stretch后的效果如下图所示

图像变换

scaleX:水平方向缩放
scaleY:垂直方向缩放
rotation:旋转
translateX:水平方向平移
translateY:水平方向平移

阴影

shadowColor
shadowOffset
shadowOpacity
shadowRadius

猜你在找的React相关文章