React Native Props(属性)使用详解

BG:

目前的Component仍然在react框架中,也就是说React Native使用的Component是react框架中的组件,而Component有两大数据管理核心State和Props。也就是说即使你仅仅想用React Native开发APP,你也需要去了解React的相关知识,比如Component、State和Props,本文主要介绍Props的使用。
State使用详解戳这里

组件(Components) 让你可以将用户界面分成独立的,可复用的小部件,并可以对每个部件进行单独的设计。你可以在这里找到详细的组件API参考

从定义上来说, 组件就像JavaScript的函数。组件可以接收任意输入(称为”props”), 并返回 React 元素,用以描述屏幕显示内容。

一、Props 是什么?

Props即属性(Property), 在代码中写作 props ,props可用作父子组件之间传值(同时对传递的数据的类型进行约束),但是子组件不能修改props,对自身来说props是只读的。

注意:
React 组件的构造函数在 挂载(mounted) 之前被调用。 在实现 React.Component 子类的构造函数时, 应该在任何其他声明之前调用super(props)。 否则,this.props 将在 constructor(构造函数) 中是 undefined(未定义) ,这将导致 bug 。

通常,React 构造函数只用于两个目的:

Note
避免复制 属性(props) 到 状态(state) ! 这是一个常见的错误:

constructor(props) {
super(props);
// Don't do this!
this.state = { color: props.color };
}

问题是,这是不必要的(直接使用 this.props.color 代替),并会>产生错误(对 color属性(props)的更新不会反映在状态中)。

仅在你故意要忽略 属性(props)更新时,使用此模式。 在这种情>况下,将 属性(props) 重命名为 initialColordefaultColor 是有>意义的。 然后,你可以强制组件通过 改变它的key 来重置它的内部状态。

如果你认为你需要一些状态(state)来依赖于这个属性(props),阅读我们的 避免派生 状态(state) 的博客文章,以了解你需要做什么。

二、Props传值

1.默认Props

通过组件类的 defaultProps 属性为 props 设置默认值,实例如下:

export default class PropComponent extends Component {
    static defaultProps={
         name: '张三',
         sex:'man',
         tel:'13866666666'
        }
}

声明defaultProps 属性后,在遇到没有被赋值的属性时,就会读取默认属性值。

2. Props赋值的几种方式

我们有下面这样一个子组件PropComponent:

export default class PropComponent extends Component {
    static defaultProps={
         name: '张三',
         sex:'man',
         tel:'13866666666'
        }
    constructor(props) {
        super(props);
    };

    render(){
        return (
            <View style={styles.container}>
                <Text>姓名:{this.props.name} 年龄:{this.props.age}  性别:{this.props.sex} 电话:{this.props.tel}</Text>
            </View>
        );
    }
}

简单赋值

<PropComponent name='张三' age=20/>

延展操作符赋值
延展操作符:...,延展操作符很方便,还可用于函数的可变参数传递。

var params = {name: '李四', age:'30', sex: 'man'};

...

<PropComponent {...params}/>
...

解构赋值
对象的解构赋值用于从一个对象取值,相当于将所有可遍历的、但尚未被读取的属性,分配到指定的对象上面.

var params2 = {name: '张解构', age: 20, sex: 'man'};
let {name, age} = params2;
...
<PropComponent name={name} age={age}/>
...

三、Props类型检查

React.PropTypes 在 React v15.5 版本后已经移到了 prop-types 库。
<script src="https://cdn.bootcss.com/prop-types/15.6.1/prop-types.js"></script>

Props 验证使用 静态propTypes,它可以保证我们的应用组件被正确使用,React.PropTypes 提供很多验证器 (validator) 来验证传入数据是否有效。当向 props 传入无效数据时,JavaScript 控制台会抛出警告。
比如校验age属性类型必须是number,当你传入的是string类型时:


image.png

示例如下:

static propTypes={
        name: PropTypes.string.isRequired,
        age: PropTypes.number,
        //要求属性取值为特定的几个值
        sex: PropTypes.oneOf(['man', 'woman']),

        //要求属性可以为指定类型中的任意一个
        tel: PropTypes.oneOfType([
            PropTypes.string,
            PropTypes.number,
          ]),
    }

全部类型检查说明:

//JS 基本数据类型
export const any: Requireable<any>;
export const array: Requireable<any[]>;
export const bool: Requireable<boolean>;
export const func: Requireable<(...args: any[]) => any>;
export const number: Requireable<number>;
export const object: Requireable<object>;
export const string: Requireable<string>;

//可以被渲染的对象 numbers, strings, elements 或 array
export const node: Requireable<ReactNodeLike>;

////  React 元素
export const element: Requireable<ReactElementLike>;

export const symbol: Requireable<symbol>;

// 用 JS 的 instanceof 操作符声明 prop 为类的实例。
export function instanceOf<T>(expectedClass: new (...args: any[]) => T): Requireable<T>;

// 用 enum 来限制 prop 只接受指定的值。
export function oneOf<T>(types: T[]): Requireable<T>;

// 可以是多个对象类型中的一个
export function oneOfType<T extends Validator<any>>(types: T[]): Requireable<NonNullable<InferType<T>>>;

 // 指定类型组成的数组
export function arrayOf<T>(type: Validator<T>): Requireable<T[]>;

// 指定类型的属性构成的对象
export function objectOf<T>(type: Validator<T>): Requireable<{ [K in keyof any]: T; }>;

//指定属性及其类型的对象
export function shape<P extends ValidationMap<any>>(type: P): Requireable<InferProps<P>>;

export function exact<P extends ValidationMap<any>>(type: P): Requireable<Required<InferProps<P>>>;

任意类型加上 isRequired 来使 prop 不可空,比如name不能为空:

static propTypes={
        name: PropTypes.string.isRequired,
        age: PropTypes.number,
    }

部分类型举例:

PropTypes.shape

//子组件CheckObjectComponent 中类型约束:
static propTypes={
        //指定属性及其类型的对象,
        position: PropTypes.shape({
            num: PropTypes.number.isRequired,
            job:PropTypes.string,
        }),
    }

//父组件调用:

var shapeParams = {name: '王五', age: 23, sex: 'man',position:{num:'1010001',job:"iOS开发"}};
...
<CheckObjectComponent position = {shapeParams. position} />
//或延展写法:
<CheckObjectComponent {...shapeParams}/>
...

PropTypes.element
约束属性是React元素,实例:

//子组件CheckElementComponent中:
export class CheckElementComponent extends Component {
    static propTypes={
        //元素
        addressElement:PropTypes.element,
    }
    
    constructor(props) {
        super(props);
    };

    render(){
        return (
            <View style={styles.container}>
                <View><Text>地址:</Text>{this.props.addressElement}</View>
            </View>
        );
    }
}

//父组件调用:
var elementParams = {addressElement:<View><Image source={require('../../images/tabBar/me_normal.png')}></Image><Text style={[{color:'blue'}]}>我在北京....</Text></View>};
...
<CheckElementComponent {...elementParams}/>

PropTypes.instanceOf

//子组件CheckInstanceOfComponent:
export class CheckInstanceOfComponent extends Component {
    static propTypes={
        //声明属性为某个类的实例
    addressElement:PropTypes.instanceOf(CheckElementComponent),
    }
    
    constructor(props) {
        super(props);
    };

    render(){
        return (
            <View style={styles.container}>
                {this.props.addressElement}
            </View>
        );
    }
}

//父组件调用:

var temElement = {addressElement:<Text style={[{color:'blue'}]}>我是instanceOf(CheckElementComponent)实例!</Text>};
var testInstance = <CheckElementComponent {...temElement}></CheckElementComponent>
...
<CheckInstanceOfComponent {...instanceOfParams}/>
...

说到props就离不开生命周期函数componentWillReceiveProps,componentWillReceiveProps函数使用注意你可以戳这里

以上是Props的使用介绍,希望能帮到你,欢迎留言交流~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容

  • 作为一个合格的开发者,不要只满足于编写了可以运行的代码。而要了解代码背后的工作原理;不要只满足于自己的程序...
    六个周阅读 8,429评论 1 33
  • 40、React 什么是React?React 是一个用于构建用户界面的框架(采用的是MVC模式):集中处理VIE...
    萌妹撒阅读 1,005评论 0 1
  • 3. JSX JSX是对JavaScript语言的一个扩展语法, 用于生产React“元素”,建议在描述UI的时候...
    pixels阅读 2,810评论 0 24
  • 以下内容是我在学习和研究React时,对React的特性、重点和注意事项的提取、精练和总结,可以做为React特性...
    科研者阅读 8,222评论 2 21
  • 首先恭喜我师父郭司令承办的,大卫博士作为连续四年冠名的年度盛典圆满成功,团队伙伴都说各种脑洞大开,提升了很多认知!...
    范双双V阅读 254评论 0 1