资讯专栏INFORMATION COLUMN

[RN] React Native style -- 样式的使用

FrozenMap / 2628人阅读

摘要:表示在上的对齐方式,基于的顶部基于的底部基于的中部布满整个。的属性所占的比例大小。它允许项目中当个和其他不一样的对齐方式,会覆盖的属性。

React-Native 样式的使用。

React-Native 编写的应用的样式不是靠css来实现的,而是依赖javascript来为你的应用来添加样式,先不讨论这样做的好处与坏处,因为这个实现方法本身就存在着很多争议,我们主要关注他的样式的语法和特性。

1.声明样式:
var styles = StyleSheet.create({
    base: {
        width: 38,
        height: 38,
    },
    background: {
        backgroundColor: "#222222",
    },
    active: {
        borderWidth: 2,
        borderColor: ‘#ff00ff",
    },
});

从语法来看:调用了React-Native的一个构造方法,传入一个对象生成style,如果你写过React就应该很熟悉这种写法,和React的React.createCladd()语法是一样的,传入对象的key就相当于类名(我是这么理解),每个类也是一个对象,可以配置各种样式参数,总体来说和CSS的写法差不多,差别上把CSS的命名又“-”连字符改成驼峰写法,然后长度不用加单位“px”,字符串比如色值需要加引号写成字符串。
其实也是和React的行内样式写法的语法一样。

2.样式的使用。

所有的核心组件都支持样式属性


当你需要设置多个属性类的时候,可以传入一个数组


在两个样式又冲突的情况下,以右边的值优先,有些情况下可以加一些条件判断样式是否加载,比如,


你也可以在组件中render样式,然而这种做法不推荐,其实就像一般html页面中行内样式不推荐一样,


3. 布局 – flexbox

React-Native 采用flexbox布局方式,flexbox是css3引入的布局模型--弹性盒子模型,旨在通过弹性的方式对齐和分布容器中的item,使其适应不同的宽度和高度。

在 React-Native 中的flexbox 是css3中flexbox的一个子集,并不支持所有的flexbox属性。
flexbox 布局分为flexbox container 和 flexbox item :如下图
RN_img_4.png
flexbox 是一个属性的集合,有些是属于container的有些是属于item的。
可以看下面这幅图:
RN_img_5.png
对于 container 有 main axis(主轴)和cross axis(交叉轴)。main size 和 cross size 分别是container主轴方向的交叉轴方向的宽度,main start 和 main end 分别是主轴的起始和结点,其他同理,container里面包含items。
下面介绍一下属性:

container的属性:
flexDirection:‘row‘|‘column‘

主轴的方向,水平 | 垂直,默认是 column ,item会按照主轴方向排列。

flexWrap:‘warp‘|‘nowrap’

flexbox 会默认将所有元素基于一行,这个属性表示是否折行。

alignItems:‘flex-start’|’flex-end’|’center’|‘stretch‘

表示item在 cross axis 上的对齐方式,基于cross axis的顶部|基于cross axis的底部|基于cross axis的中部|布满整个。

justifyContent:‘flex-start’|‘flex-end‘|‘center‘|‘space-between‘|’space-around’

表示item在 main axis 上的对齐方式,基于主轴开始|基于主轴结束|居中|左右两边对齐,item间隔相等|每个item两端间隔相等。

item的属性
flex: num

item 所占的比例大小。

alignSelf:‘ flex-start ’ | ’ flex-end ’ | ’ center ’ | ‘ stretch ‘

它允许项目中当个item和其他itemsyou不一样的对齐方式,会覆盖alignitems的属性。

可以看我的个人blog的文章 阿城|blog

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/86253.html

相关文章

  • React-Native

    摘要:系统存在启动鱼销毁一个的一条有序的回调函数。一个,继承子所在应用进程的窗口管理器有一个主要用来管理窗口的一些状态,属性,增加,删除,更新,窗口顺序,消息收集和处理等。通过接口与全局窗口管理器进行交互界面控制和消息响应。 安装 iOS启动注意 在xcode项目代码中AppDelegate.m会标识入口文件。例如:jsCodeLocation = [NSURL URLWithString...

    bbbbbb 评论0 收藏0
  • react native 实现类似QQ侧滑列表效果

    摘要:因而对于现有的普通列表界面,要替换成侧滑列表,改动相对小些。如果想要实现类似那样的侧滑效果,就不能给每个按钮都设置背景色,需要稍微投机取巧下。相关代码有分组的侧滑列表无分组的侧滑列表 如果列表行数据需要更多的操作,使用侧滑菜单是移动端比较常见的方式,也符合用户的操作习惯,对app的接受度自然会相对提高点。最近得空就把原来的react-native项目升级了侧滑操作,轻轻松松支持andr...

    张巨伟 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<