前言

  • 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习

  • 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所偏差,在学习中如果有错会及时修改内容,也欢迎万能的朋友们批评指出,谢谢

  • 文章第一版出自简书,如果出现图片或页面显示问题,烦请转至 简书 查看 也希望喜欢的朋友可以点赞,谢谢

Text 组件介绍


  • 在 React Native 用于显示文本的组件就是 Text,和iOS中的 UIlabel,Android中的 TextView类似,专门用来显示基本的文本信息,处理基本的显示布局外,还可以进行嵌套显示,设置样式,已经事件处理(如:点击事件)

Text 组件常用的属性和方法


  • color:字体颜色

    	// 字体颜色
    color:'blue'

    效果:

  • numberOfLines:设置 Text 显示文本的行数,如果显示的内容超过行数,默认其余的文本信息不再显示

    	render() {
    return (
    <View style={styles.container}>
    <Text style={styles.textStyle} numberOfLines={3}>雨泽Forest雨泽Forest雨泽Forest雨泽Forest雨泽Forest雨泽Forest雨泽Forest雨泽Forest雨泽Forest</Text>
    </View>
    );
    }

    效果:

  • fontSize:字体大小

    	// 字体大小
    fontSize:30

    效果:

  • fontFamily:字体名称

    	// 字体类型
    fontFamily:'Georgia'

    效果:

  • fontStyle('normal', 'italic'):字体风格

    	// 字体风格
    fontStyle:'italic'

    效果:

  • fontWeight('normal', 'bold', '100 ~ 900'):指定字体的粗细。大多数字体都支持'normal'和'bold'值。并非所有字体都支持所有的数字值。如果某个值不支持,则会自动选择最接近的值

    	// 字体粗细
    fontWeight:('bold', '700')

    效果:

  • textShadowOffset(width: number, height: number):设置阴影效果

  • textShadowColor:阴影效果颜色

    	// 阴影
    textShadowOffset:{width:3, height:5},
    // 阴影颜色
    textShadowColor:'black'

    效果:

  • textShadowRadius:阴影效果圆角(值越大阴影越模糊)

    	// 阴影圆角
    textShadowRadius:3

    效果:

  • letterSpacing:字符间距

    	// 字符间距
    letterSpacing:5

    效果:

  • lineHeight:行高

    	// 行高
    lineHeight:25

    效果:

  • textAlign('auto', 'left', 'right', 'center', 'justify'):文本对齐方式

    • auto
    	// 文本对齐方式
    textAlign:'auto'

    效果:

    • left
    	// 文本对齐方式
    textAlign:'left'

    效果:

    • right
    	// 文本对齐方式
    textAlign:'right'

    效果:

    • center
    	// 文本对齐方式
    textAlign:'center'

    效果:

    • justify
    	// 文本对齐方式
    textAlign:'justify'

    效果:

  • textDecorationLine('none', 'underline', 'line-through'):横线位置

    • none:没有横线
    • underline:
    	// 横线
    textDecorationLine:'underline'

    效果:

    • line-through:
    	// 横线
    textDecorationLine:'line-through'

    效果:

  • textDecorationStyle('solid', 'double', 'dotted', 'dashed'):线风格

    • solid
    	// 横线风格
    textDecorationStyle:'solid'

    效果:

    • double
    	// 横线风格
    textDecorationStyle:'double'

    效果:

    • dotted
    	// 横线风格
    textDecorationStyle:'dotted'

    效果:

    • dashed
    	// 横线风格
    textDecorationStyle:'dashed'

    效果:

  • textDecorationColor:线的颜色

    	// 线的颜色
    textDecorationColor:'black',

    效果:

  • allowFontScaling:控制字体是否要根据iOS的“文本大小”辅助选项来进行缩放

  • adjustsFontSizeToFit:指定字体是否随着给定样式的限制而自动缩放

  • minimumFontScale:当adjustsFontSizeToFit开启时,指定最小的缩放比(即不能低于这个值)。可设定的值为0.01 - 1.0

  • suppressHighlighting:当为true时,如果文本被按下,则没有任何视觉效果。默认情况下,文本被按下时会有一个灰色的、椭圆形的高光

  • selectable:决定用户是否可以长按选择文本,以便复制和粘贴

    	render() {
    return (
    <View style={styles.container}>
    <Text style={styles.textStyle}
    selectable={true}
    >
    雨泽Forest
    </Text>
    </View>
    );
    }

    效果:

  • testID:用来在端到端测试中标记这个视图

  • onPress:当文本发生点击的时候调用该方法

    	render() {
    return (
    <View style={styles.container}>
    <Text style={styles.textStyle}
    onPress={()=>{alert('点击')}}
    >
    雨泽Forest
    </Text>
    </View>
    );
    }

    效果:

  • onLongPress:当文本被长按以后调用此回调函数(参考onPress)

  • onLayout:当挂载或者布局变化以后调用(参数为:{nativeEvent: {layout: {x, y, width, height}}})(参考onPress)

Text 使用


  • 视图部分

    	render() {
    return (
    <View style={styles.container}>
    <Text style={styles.textStyle}>雨泽Forest</Text>
    </View>
    );
    }
  • 样式部分

    	var styles = StyleSheet.create({
    container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: 'green',
    }, textStyle: {
    // 背景色
    backgroundColor:'yellow',
    // 字体大小
    fontSize:30,
    // 下划横线
    textDecorationLine:'underline'
    } });

    效果:

Text 组件的嵌套使用


  • 视图部分

    	var test = React.createClass({
    render() {
    return (
    <View style={styles.container}>
    <Text style={styles.textStyle} numberOfLines={3}>
    雨泽
    <Text style={{color:'orange'}}>
    Forest
    </Text>
    </Text>
    </View>
    );
    }
    });
  • 样式部分

    	var styles = StyleSheet.create({
    container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: 'green',
    }, textStyle: {
    // 字体颜色
    color:'blue',
    // 字体大小
    fontSize:30
    } });

    效果:

Text 组件中样式的继承


  • 在 React Native 中是没有样式继承这种说法的,但对于 Text 元素里边的 Text 元素,其实是可以继承的,至于是单继承还是多继承,我们可以来试验一下

    • 视图部分
    	var test = React.createClass({
    render() {
    return (
    <View style={styles.container}>
    <Text style={styles.textStyle} numberOfLines={3}>
    <Text>
    <Text>雨泽Forest</Text>
    </Text>
    </Text>
    </View>
    );
    }
    });
    • 样式部分
    	var styles = StyleSheet.create({
    container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: 'green',
    }, textStyle: {
    // 字体颜色
    color:'blue',
    // 字体大小
    fontSize:30
    } });

    效果:

  • 通过试验我们可以看出,文字控制类的属性也是多继承的,和 CSS 是一样的,而且会取与自己最近的属性归自己所用,也就是说属性可覆盖

很多朋友私信我说更新太慢,在这里说声抱歉,因为接近春节,公司事情比较多,还请朋友们见谅,喜欢我的文章的可以点点关注,有什么不清楚或者建议可以评论或留言,谢谢!

React Native 之 Text的使用的更多相关文章

  1. React Native & Android & Text Input

    React Native & Android & Text Input react native clear input value https://stackoverflow.com ...

  2. React-Native(五):React Native之Text学习

    本章节主要学习Text的布局,仿照网易新网: 代码: /** * Sample React Native App * https://github.com/facebook/react-native ...

  3. React Native图片控件的使用

    首先定义组件 import { AppRegistry, StyleSheet, Text, View, Image,} from 'react-native'; 然后将render返回中的模版增加I ...

  4. 《React Native 精解与实战》书籍连载「配置 iOS 与 Android 开发环境」

    此文是我的出版书籍<React Native 精解与实战>连载分享,此书由机械工业出版社出版,书中详解了 React Native 框架底层原理.React Native 组件布局.组件与 ...

  5. <React Native移动开发实战>-1-React Native的JSX解决方案

    JSX并不是一门新的开发语言,而是Facebook提出的语法方案:一种可以在JavaScript代码中直接书写HTML标签的语法糖,所以,JSX本质上还是JavaScript语言. 小知识:语法糖(S ...

  6. react native组件的创建

    react native组件的创建 react文件加载顺序: react项目启动后,先加载index.js.在index.js中可以指向首页. import { AppRegistry } from ...

  7. 【React Native】在原生和React Native间通信(RN调用原生)

    一.从React Native中调用原生方法(原生模块) 原生模块是JS中也可以使用的Objective-C类.一般来说这样的每一个模块的实例都是在每一次通过JS bridge通信时创建的.他们可以导 ...

  8. React Native JSX value should be expression or a quoted JSX text.

    问题描述:  我在使用props时候, 我的写法是这样的 ... <View> <Person name='john' age=32 gender=true></Pers ...

  9. React Native组件之Text

    React Native组件之Text相当于iOS中的UILabel. 其基本属性如下: /** * Sample React Native App * https://github.com/face ...

随机推荐

  1. NodeJs之pm2

    pm2 pm2是一个进程管理工具,可以用它来管理你的node进程,并查看node进程的状态,当然也支持性能监控,进程守护,负载均衡等功能. 开发过程中建议时不时的参看官方详细命令行使用:命令行 pm2 ...

  2. NodeJs之OS

    OS Node.js提供了一些基本的底层操作系统的模块OS. API var os = require('os'); console.log('[arch] 操作系统CPU架构'+os.arch()) ...

  3. 微软.NET Core RC2正式发布,横跨所有平台

    .NET官方博客宣布了<Announcing .NET Core RC2 and .NET Core SDK Preview 1>,正式如期发布了.NET Core RC2, 现在可以放心 ...

  4. Asp.Net WebApi核心对象解析(上篇)

    生活需要自己慢慢去体验和思考,对于知识也是如此.匆匆忙忙的生活,让人不知道自己一天到晚都在干些什么,似乎每天都在忙,但又好似不知道自己到底在忙些什么.不过也无所谓,只要我们知道最后想要什么就行.不管怎 ...

  5. Java compiler level does not match解决方法

    从别的地方导入一个项目的时候,经常会遇到eclipse/Myeclipse报Description  Resource Path Location Type Java compiler level d ...

  6. equals变量在前面或者在后面有什么区别吗?这是一个坑点

    我就不废话那么多,直接上代码: package sf.com.mainTest; public class Test { public static void main(String[] args) ...

  7. git init和git init -bare区别

    1 Git init  和 git init –bare 的区别 用"git init"初始化的版本库用户也可以在该目录下执行所有git方面的操作.但别的用户在将更新push上来的 ...

  8. 如何dos命令打开服务窗口?

    1.输入services.msc点击<确定>进入服务窗口.如图:

  9. python-time 模块

    1.时间戳是以秒为单位的浮点小数,时间戳以自1970年1月1日午夜到现在经过了的时间来表示 2.时间模块引入方式:import time 3.返回时间戳 time.time() 4.返回时间元组:ti ...

  10. [转载]MVVM模式原理分析及实践

    没有找到很好的MVVM模式介绍文章,简单找了一篇,分享一下.MVVM实现了UI\UE设计师(Expression Blend 4设计界面)和软件工程师的合理分工,在SilverLight.WPF.Wi ...