ReactNative—Text标签中的Style学习

Stella981
• 阅读 806

1.引用需要的组件

这里用到_AppRegistry,StyleSheet,Text,View_

import React, { Component } from 'react';
import {
  AppRegistry,//JS运行所有React Native应用的入口,必须引用
  StyleSheet,//样式
  Text,//文本框
  View,//视图
} from 'react-native';

2.所有的标签都必须包含在内部。

3.标签为文本标签。可选属性有以下:

  • numberOfLines 文本行数限制,添加后超过限制行数文本会在末尾默认以...的形式省略。
  • ellipsizeMode 设置文本缩略格式,配合numberOfLines使用.
  • onPress 点击事件
  • style 样式

4.style样式的创建。

  • 可以直接在Text标签内写样式  style={{}}

    <Text numberOfLines={1} style={{color:'blue'}}> 121212121212121212121212

  • 也可以类似网页里写样式文件一样,用StyleSheet.create({ })创建自定义的style样式.

例:创建mystyle1和mystyle2样式

const styles = StyleSheet.create({
   mystyle1: {
      color:'red',//颜色
    fontSize: 10,//字号
    textAlign: 'center',//居中
    
  },
  mystyle2:{
      fontSize:35,//字号
      fontWeight:'bold',//粗细
      textAlign:'center',//居中
      fontStyle:'italic',//斜体
      color:'blue',//颜色
      textDecorationLine:'underline'//下划线
  }
});

5.自定义样式的引用。

属性的引用方式为   属性name={属性值}。

 <View style={styles.container}>
        <Text numberOfLines={1}    style={styles.mystyle2}>
            121212121212121212121212
        </Text>
</View>

运行结果:(可以看到行数限制和mystyle2样式都已经生效)

ReactNative—Text标签中的Style学习

6.关于样式的继承。

解释:字体样式的继承,即将Text嵌套于其他Text时,内部的 Text 组件可以继承外部 Text 组件的样式。

先上总体结论:

Text标签互相嵌套时:
1.自身无样式,则可继承外部Text样式。
2.自身样式和外部Text样式冲突,自身样式优先级最高,覆盖其他冲突样式。
3.自身样式和外部Text样式存在部分冲突,则冲突的样式自身优先级最高覆盖外部Text样式,其他不冲突的样式可实现继承样式。

实例1:

《1》内部的不设置样式,外部的设置样式

  //外部的样式设置为蓝色,内部的Text不写样式 
 <Text numberOfLines={1}    style={{color:'blue'}}>
        <Text>
             121212121212121212121212
        </Text>
  </Text>

运行结果(外部的蓝色设置生效。):

ReactNative—Text标签中的Style学习

《2》内部的设置样式,外部的设置不同的样式,样式冲突的情况。

//内部设置样式颜色为红色,和外部Text样式冲突 
 <Text numberOfLines={1}    style={{color:'blue'}}>
        <Text style={{color:'red'}}>
             121212121212121212121212
        </Text>
  </Text>

运行结果(冲突时,内部的红色生效):

ReactNative—Text标签中的Style学习

《3》内部的设置样式,外部的设置不同的样式,样式不冲突的情况。

//内部设置样式颜色为红色,和外部Text样式蓝色冲突,但是外部样式多了一个下划线 
 <Text numberOfLines={1}    style={{color:'blue',textDecorationLine:'underline'}}>
        <Text style={{color:'red'}}>
             121212121212121212121212
        </Text>
  </Text>

运行结果(冲突的部分内部样式覆盖外部样式,即自身样式覆盖其他样式,自身样式权重最大优先级最高。内部不存在的样式,会继承外部的样式,如示例中的下划线):

ReactNative—Text标签中的Style学习

7.样式先后顺序的影响。

在同一个Text内写两个(多个)样式对象,或者引用两个(多个)样式时,后引用的覆盖先引用的。

示例:

同时引用两个样式style={{样式1},{样式2}}先设置样式蓝色,后设置红色:

     <View style={styles.container}>
        <Text numberOfLines={1}    
         style={{color:'blue',textDecorationLine:'underline'},{color:'red'}}>
             测试引用两个不同的样式
        </Text>
      </View>

ReactNative—Text标签中的Style学习

 后写的红色生效,并且没有样式1中的下划线。反过来把红色放前边,则蓝色生效。

结论:当两个(多个)样式引用时,后边的会覆盖前边的,而且是直接覆盖,跟样式继承的区别是即使不冲突的属性也会被覆盖。

附上源码

/**
 * Sample React Native App
 * https://github.com/facebook/react-native
 * @flow
 */

import React, { Component } from 'react';
import {
  AppRegistry,
  StyleSheet,
  Text,
  View,
  Button,
  Alert
} from 'react-native';
//引入navbar

export default class MyFirstDemo extends Component {
  render() {
      
    return (
      <View style={styles.container}>
        <Text numberOfLines={1}    style={styles.mystyle2}>
             121212121212121212121212
            <Text  style={styles.style1}>
             1231231111
            </Text>
            <Text >
             123123aaaa
            </Text>
        </Text>
        <Text style={styles.instructions}>
          To get started, edit index.android.js
        </Text>
        <Text style={styles.instructions}>
          Double tap R on your keyboard to reload,{'\n'}
          Shake or press menu button for dev menu
        </Text>
        <Button title="跳转页面" onPress={onButtonPress} >
            
        </Button>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
  mystyle1: {
      color:'red',
    fontSize: 10,
    textAlign: 'center',
    margin: 10,
  },
  mystyle2:{
      fontSize:35,
      fontWeight:'bold',
      textAlign:'center',
      fontStyle:'italic',
      color:'blue',
      textDecorationLine:'underline'
  },
  instructions: {
    textAlign: 'center',
    color: '#333333',
    marginBottom: 5,
  }
  
});
const onButtonPress=()=>{
  Alert.alert('Button has been pressed!');
}
AppRegistry.registerComponent('MyFirstDemo', () => MyFirstDemo);
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
AndroidStudio封装SDK的那些事
<divclass"markdown\_views"<!flowchart箭头图标勿删<svgxmlns"http://www.w3.org/2000/svg"style"display:none;"<pathstrokelinecap"round"d"M5,00,2.55,5z"id"raphael
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这