React Native样式(style)及布局属性(flexDirection、justifyContent、alignItems、flex)

一、style样式的几种写法

import React, { Component } from 'react'
import { StyleSheet, Text, View } from 'react-native'
import index from './index'

export default class teststyle extends Component {
  render() {
    return (
        <View>
        <Text style={{fontSize:40}}> textInCom2122ponent </Text>
        <Text style={[{color:'red'},{color:'green'}]}> textInCom2122ponent </Text>
        <Text style={styles.h1}> textInCom2122ponent </Text>
      </View>
    )
  }
}

const styles=StyleSheet.create({
    h1:{
        color:'blue'
    }
})

二、布局

main axis:主轴

cross axis:交叉轴

 布局常用四种属性:

    flexDirection:'row',//主轴方向

    justifyContent:'center',//主轴对齐方式

    alignItems:'flex-start'//项目在交叉轴的对齐方式

    flex:项目在主轴上的尺寸比例

import React, { Component } from 'react'
import { Text, StyleSheet, View } from 'react-native'

export default class testflexDirection extends Component {
  render() {
    return (
      <View>
        <View style={[styles.flexrow]}>
           <Text> 张三 </Text>
           <Text> 李四 </Text>
           <Text> 王五 </Text>
        </View>
        <View style={[styles.flexcol]}>
           <Text> 张三 </Text>
           <Text> 李四 </Text>
           <Text> 王五 </Text>
        </View>

        <View style={[styles.flexrow1]}>
           <Text style={{flex:1}}> 张三 </Text>
           <Text style={{flex:2}}> 李四 </Text>
           <Text style={{flex:3}}> 王五 </Text>
        </View>

      </View>
    )
  }
}

const styles = StyleSheet.create({
  flexrow:{
    flexDirection:'row',//主轴方向
    justifyContent:'center',//主轴对齐方式
    alignItems:'flex-start',//项目在交叉轴的对齐方式
    borderWidth:2,
    borderColor:'red'
  },
  flexrow1:{
    flexDirection:'row',//主轴方向
    alignItems:'flex-start',//项目在交叉轴的对齐方式
    borderWidth:2,
    borderColor:'red'
  },
  flexcol:{
    flexDirection:'column',//主轴方向
    justifyContent:'center',//主轴对齐方式
    alignItems:'center',//项目在交叉轴的对齐方式
    borderWidth:2,
    borderColor:'red'
  },

})

三、响应式部署

import React, { Component } from 'react'
import { Text, StyleSheet, View,Dimensions } from 'react-native'

export default class testDimensions extends Component {
  render() {
    return (
      <View style={styles.container}> 
      <View style={styles.item} >
        <Text> 扫一扫 </Text>
      </View>
      <View style={styles.item}>
        <Text> 钱包 </Text>
      </View>
      <View style={styles.item}>
        <Text> 卡包 </Text>
      </View>
      <View style={styles.item}>
        <Text> 出行 </Text>
      </View>
      </View>
    )
  }
}

const styles = StyleSheet.create({
    container:{
         flexDirection:'row'
    },
    item:{
        width:Dimensions.get('window').width/4,//响应式布局
        borderWidth:1,
        borderColor:'red'
    }
})

 

  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值