百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

React-Native 样式指南(react-native-view-shot)

toyiye 2024-07-16 05:59 32 浏览 0 评论

React-Native 样式指南

React-Native 的样式基本上是实现了 CSS 的一个子集,并且属性名不完全一致,所以当你开始在编写 React-Native 之前,可以先简要了解一下。

目录

  • Properties 属性
    • Text 文本
    • Dimension 尺寸
    • Positioning 定位
    • Margin 外部白
    • Padding 内补白
    • Border 边框
    • Background 背景
    • Transform 转换
    • Flexbox 弹性盒
    • Other 其他
  • Values 取值
    • Color 颜色
    • Number 数值
  • Units 单位
    • Pt 点
  • PixelRatio 像素密度

Properties 属性

Text 文本(18)

属性名

取值

描述

color

<color>

对应 CSS color 属性

fontFamily

string

对应 CSS font-family 属性

fontSize

<number>

对应 CSS font-size 属性

fontStyle

normal, italic

对应 CSS font-style 属性,但阉割了 oblique 取值

fontWeight

normal, bold 100~900

对应 CSS font-weight 属性,但阉割了 bolder, lighter 取值

lineHeight

<number>

对应 CSS line-height 属性

textAlign

auto, left, right, center, justifyiOS

对应 CSS text-align 属性,但增加了 auto 取值。当取值为 justify 时,在 Android 上会变为 left

textDecorationLine

none, underline, line-through, underline line-through

对应 CSS text-decoration-line 属性,但阉割了 overline, blink 取值

textShadowColor

<color>

对应 CSS text-shadow 属性中的颜色定义

textShadowOffset

{
width:<number>,
height:<number>
}

对应 CSS text-shadow 属性中的阴影偏移定义

textShadowRadius

<number>

在 CSS 中,阴影的圆角大小取决于元素的圆角定义,不需要额外定义

includeFontPadding
Android

<bool>

Android在默认情况下会为文字额外保留一些padding,以便留出空间摆放上标或是下标的文字。对于某些字体来说,这些额外的padding可能会导致文字难以垂直居中。如果你把textAlignVertical设置为center之后,文字看起来依然不在正中间,那么可以尝试将本属性设置为false

textAlignVertical
Android

auto, top, bottom, center

对应 CSS vertical-align 属性,增加了 auto 取值,center 取代了 middle,并阉割了 baseline, sub 等值

fontVariant
iOS

small-caps, oldstyle-nums, lining-nums, tabular-nums, proportional-nums

对应 CSS font-variant 属性,但取值更丰富

letterSpacing
iOS

<number>

对应 CSS letter-spacing 属性

textDecorationColor
iOS

<color>

对应 CSS text-decoration-color 属性

textDecorationStyle
iOS

solid, double, dotted, dashed

对应 CSS text-decoration-style 属性,但阉割了 wavy 取值

writingDirection
iOS

auto, ltr, rtl

对应 CSS direction 属性,增加了 auto 取值

Dimension 尺寸(6)

属性名

取值

描述

width

<number>

对应 CSS width 属性

minWidth

<number>

对应 CSS min-width 属性

maxWidth

<number>

对应 CSS max-width 属性

height

<number>

对应 CSS height 属性

minHeight

<number>

对应 CSS min-height 属性

maxHeight

<number>

对应 CSS max-height 属性

Positioning 定位(6)

属性名

取值

描述

position

absolute, relative

对应 CSS position 属性,但阉割了 static, fixed 取值

top

<number>

对应 CSS top 属性

right

<number>

对应 CSS right 属性

bottom

<number>

对应 CSS bottom 属性

left

<number>

对应 CSS left 属性

zIndex

<number>

对应 CSS z-index 属性

Margin 外部白(7)

属性名

取值

描述

margin

<number>

对应 CSS margin 属性,不同的是,它只能定义一个参数,如需分别定义上、右、下、左4个方位的外补白,可以通过下面的单向外部白属性

marginHorizontal

<number>

无对应的 CSS 属性。其效果相当于同时设置 marginRight 和 marginLeft

marginVertical

<number>

无对应的 CSS 属性。其效果相当于同时设置 marginTop 和 marginBottom

marginTop

<number>

对应 CSS margin-top 属性

marginRight

<number>

对应 CSS margin-right 属性

marginBottom

<number>

对应 CSS margin-bottom 属性

marginLeft

<number>

对应 CSS margin-left 属性

Padding 内部白(7)

属性名

取值

描述

padding

<number>

对应 CSS padding 属性,不同的是,它只能定义一个参数,如需分别定义上、右、下、左4个方位的内补白,可以通过下面的单向内部白属性

paddingHorizontal

<number>

无对应的 CSS 属性。其效果相当于同时设置 paddingRight 和 paddingLeft

paddingVertical

<number>

无对应的 CSS 属性。其效果相当于同时设置 paddingTop 和 paddingBottom

paddingTop

<number>

对应 CSS padding-top 属性

paddingRight

<number>

对应 CSS padding-right 属性

paddingBottom

<number>

对应 CSS padding-bottom 属性

paddingLeft

<number>

对应 CSS padding-left 属性

Border 边框(20)

属性名

取值

描述

borderStyle

solid, dotted, dashed

对应 CSS border-style 属性,但阉割了 none, hidden, double, groove, ridge, inset, outset 取值,且无方向分拆属性

borderWidth

<number>

对应 CSS border-width 属性

borderTopWidth

<number>

对应 CSS border-top-width 属性

borderRightWidth

<number>

对应 CSS border-right-width 属性

borderBottomWidth

<number>

对应 CSS border-bottom-width 属性

borderLeftWidth

<number>

对应 CSS border-left-width 属性

borderColor

<color>

对应 CSS border-color 属性

borderTopColor

<color>

对应 CSS border-top-color 属性

borderRightColor

<color>

对应 CSS border-right-color 属性

borderBottomColor

<color>

对应 CSS border-bottom-color 属性

borderLeftColor

<color>

对应 CSS border-left-color 属性

borderRadius

<number>

对应 CSS border-radius 属性

borderTopLeftRadius

<number>

对应 CSS border-top-left-radius 属性

borderTopRightRadius

<number>

对应 CSS border-top-right-radius 属性

borderBottomLeftRadius

<number>

对应 CSS border-bottom-left-radius 属性

borderBottomRightRadius

<number>

对应 CSS border-bottom-right-radius 属性

shadowColor

<color>

对应 CSS box-shadow 属性中的颜色定义

shadowOffset

{
width: <number>,
height: <number>
}

对应 CSS box-shadow 属性中的阴影偏移定义

shadowRadius

<number>

在 CSS 中,阴影的圆角大小取决于元素的圆角定义,不需要额外定义

shadowOpacity

<number>

对应 CSS box-shadow 属性中的阴影透明度定义

Background 背景(1)

属性名

取值

描述

backgroundColor

<color>

对应 CSS background-color 属性

Transform 转换(3)

属性名

取值

描述

transform

[{perspective: number}, {rotate: string}, {rotateX: string}, {rotateY: string}, {rotateZ: string}, {scale: number}, {scaleX: number}, {scaleY: number}, {translateX: number}, {translateY: number}, {skewX: string}, {skewY: string}]

对应 CSS transform 属性

transformMatrix

TransformMatrixPropType

类似于 CSS 中 transform 属性的 matrix() 和 matrix3d() 函数

backfaceVisibility

visible, hidden

对应 CSS backface-visibility 属性

Flexbox 弹性盒(9)

属性名

取值

描述

flex

<number>

对应 CSS flex 属性,但只能为整数值

flexGrow

<number>

对应 CSS flex-grow 属性

flexShrink

<number>

对应 CSS flex-shrink 属性

flexBasis

<number>

对应 CSS flex-basis 属性

flexDirection

row, row-reverse, column, column-reverse

对应 CSS flex-direction 属性

flexWrap

wrap, nowrap

对应 CSS flex-wrap 属性,但阉割了 wrap-reverse 取值

justifyContent

flex-start, flex-end, center, space-between, space-around

对应 CSS justify-content 属性,但阉割了 stretch 取值。

alignItems

flex-start, flex-end, center, stretch

对应 CSS align-items 属性,但阉割了 baseline 取值。

alignSelf

auto, flex-start, flex-end, center, stretch

对应 CSS align-self 属性,但阉割了 baseline 取值

Other 其他

属性名

取值

描述

opacity

<number>

对应 CSS opacity 属性

overflow

visible, hidden, scroll

对应 CSS overflow 属性,但阉割了 auto 取值

elevation
Android

<number>

CSS中没有对应的属性,只在 Android5.0+ 上有效

resizeMode

cover, contain, stretch

CSS中没有对应的属性,可以参考 background-size 属性

overlayColor
Android

string

CSS中没有对应的属性,当图像有圆角时,将角落都充满一种颜色

tintColor
iOS

<color>

CSS中没有对应的属性,iOS 图像上特殊的色彩,改变不透明像素的颜色

Valuse 取值

Color 颜色

React Native 支持了 CSS 中大部分的颜色类型:

  • #f00 (#rgb)
  • #f00c (#rgba):CSS 中无对应的值
  • #ff0000 (#rrggbb)
  • #ff0000cc (#rrggbbaa):CSS 中无对应的值
  • rgb(255, 0, 0)
  • rgba(255, 0, 0, 0.9)
  • hsl(360, 100%, 100%)
  • hsla(360, 100%, 100%, 0.9)
  • transparent
  • 0xff00ff00 (0xrrggbbaa):CSS 中无对应的值
  • Color Name:支持了 基本颜色关键字 和 拓展颜色关键字,但不支持 28个系统颜色;

Number 数值

在 React-Native 中,目前仅支持 Number 这一种长度取值。默认缺省了 pt 单位,详细请看 Units 单位 部分。

Units 单位

Pt 点

在 React-Native 中,并不支持百分比单位,目前只支持一种单位,即 pt 绝对长度单位,同时,你在定义时不需要加单位,例如:

<View style={{width: 100, height: 50}}></View>
var styles = StyleSheet.create({
    box: {
        width: 100,
        height: 50
    }
});

PixelRatio 像素密度

在 React-Native 中,访问设备像素密度的方法由 PixelRatio 类提供。

我们的应用通常都会运行在不同的设备上,并且这些设备的像素密度很有可能各不相同。这会造成一个现象就是:

  • 定义了元素的边框为 1像素,而实际上在不同像素密度的设备上结果不一样,比如:iPhone6 显示为 2像素,iPhone6 Plus 显示为 3像素;
  • 对于一个图片来讲,因为设备的像素密度不同,它也需要对应不同尺寸的规则,以防止图片过小变得模糊;

根据像素密度指定边框厚度

出于对产品体验的一致性,我们会要求不论是在哪种设备上,其边框厚度都应该是相同的。一个取得物理上的相同边框厚度的好方法就是用逻辑尺寸除以像素密度比:

var styles = StyleSheet.create({
    box: {
        borderWidth: 1 / PixelRatio.get(),
        borderStyle: solid
    }
});

上述代码将保证你的应用在所有的设备上(像素密度),都获得 1像素 的边框厚度。PixelRatio 通过 get() 方法来返回设备的像素密度。

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码