父组件给子组件传值时:

1、defaultProps:父子组件传值中,如果父组件调用子组件的时候不给子组件传值,可以在子组件中使用defaultProps定义的默认值;

2、propTypes:验证父组件传值的类型合法性(注意:类.propTypes、 PropTypes.string; propTypes有两种写法且都是固定的)propTepes的使用分为两步:

        1、引入import PropTypes from 'prop-types';

        2、类.propTypes = {
name: PropTypes.string //还有指定数字类型:PropTypes.number
};

3、以上两条都是定义在子组件里面

官方文档:https://reactjs.org/docs/typechecking-with-proptypes.html

一、defaultProps示例:

父组件【Home.js】

import React, { Component } from 'react';
import Header from './Header'; //引入header.js
import '../assets/css/index.css'; class Home extends Component { constructor(props){
super(props);
this.state={
title:'首页组件传的标题', //1.待传入子组件的消息
count:20
}
}
render() {
return (
<div> {/* 2.此处传入title,header将显示首页组件 */}
<Header title={this.state.title} /> <br/> {/* 3.此处不传入title,将显示header提供的默认值:header默认标题 */}
<Header/> <hr />
<br />
这是首页组件的内容
</div>
);
}
}
export default Home;

子组件:【Header.js】

import React, { Component } from 'react';

class Header extends Component {
constructor(props) {
super(props);
this.state = {
msg:"我是一个头部组件"
};
}
render() {
return (
<div>
{/* 2.接收父组件传过来的title值;(此处如果父组件不传title,将显示“Header默认标题”) */}
<h2>---{this.props.title}---</h2>
</div>
);
}
} // 1.defaultProps 如果父组件调用子组件的时候不给子组件传值,可以在子组件中使用defaultProps定义的默认值
Header.defaultProps={
title:'Header默认标题'
}
export default Header;

根组件:【app.js】

import React, { Component } from 'react';
import Home from './components/Home'; class App extends Component {
render (){
return(
<div className="App">
<Home />
</div>
)}
}
export default App;

结果:

二、propTypes示例

父组件【Home.js】:

import React, { Component } from 'react';
import Header from './Header'; //引入header.js
import '../assets/css/index.css'; class Home extends Component {
constructor(props){
super(props);
this.state={
//title:'首页组件',
count:20
}
}
render() {
return (
<div>
{/*1.此处向子组件,传入字符串控制台将有警告: */}
<Header num='aaaaaaaaaaaaa' />
<br/> {/* 2.此处传入state.count的数字20,将正常显示<Header num={this.state.count} />*/} <hr />
<br />
这是首页组件的内容
</div>
);
}
}
export default Home;

子组件【Header.js】

import React, { Component } from 'react';

// 1.要使用PropTypes 首先要引入它的包
import PropTypes from 'prop-types'; class Header extends Component {
constructor(props) {
super(props);
this.state = {
msg:"我是一个头部组件"
};
}
render() {
return (
<div>
<h2>---{this.props.num}---</h2>
</div>
);
}
} /* 2.同行propTypes定义父组件给子组件传值的类型,此处.number是数字类型;
如果父组件传入的传非数字,会在控制台(console)警告:
Warning: Failed prop type: Invalid prop `num` of type `string` supplied to `Header`, expected `number`.
*/
Header.propTypes={
num:PropTypes.number
}
export default Header;

根组件【App.js】

代码:同一示例

【效果1】,传入字符串时有警告:



【效果2】,传入数值将正常:

十、React 父组件传来值的类型控制propTypes、父组件如果不传值defaultProps的更多相关文章

  1. 8. react 基础 - props 默认值和类型限制 与 Props , State , render 函数 关系

    一. PropTypes 与 DefaultProps 官方文档 1. PropTypes 属性校验 引入 PropTypes import PropTypes from 'prop-types'; ...

  2. Vue 父组件主动获取子组件的值,子组件主动获取父组件的值

    父组件主动获取子组件的值 1. 在调用子组件的时候定义一个ref-> ref="header"2. 在父组件中通过this.$refs.header.属性,调用子组件的属性, ...

  3. vue 子组件修改父组件传来的props值,报错

    vue不推荐直接在子组件中修改父组件传来的props的值,会报错 [Vue warn]: Avoid mutating a prop directly since the value will be ...

  4. reac——父组件向子组件传递值,子组件何时能同步获得父组件改变后的值

    //这里是父组件的代码:export default class HeaderCom_son extends React.Component { constructor(props) { super( ...

  5. 14. VUE 子组件修改父组件的值

    在 Vue 当中,父组件 -> 子组件 传值,都是通过属性的形式传递的. 子组件 修改 传递数据 直接操作父组件传递过来的值,用是可以用的,但是打开控制台后,会发现 Vue 有个警告:你不要直接 ...

  6. Vue-自定义事件之—— 子组件修改父组件的值

    如何利用自定义的事件,在子组件中修改父组件里边的值? 关键点记住:三个事件名字 步骤如下: 这里,相对本案例,父组件定义为Second-module,对应的子组件是Three-module 第一步:你 ...

  7. react+dva 全局model中异步获取数据state在组件中取不到值

    先上结论,不是取不到,是写法有问题. 全文分4部分,1是问题描述,2是一开始的解决想法(错误做法),3是问题产生原因的思考,4是正常解决方法.只想看结论直接跳4 1.问题描述 接触react dva一 ...

  8. vue中.sync修饰符,实现子组件实时更新父组件的值

    vue 修饰符sync的功能是:当一个子组件改变了一个 prop 的值时,这个变化也会同步到父组件中所绑定. 不过它有一个前身,先来看看.sync出现之前是如何实现的 父组件中(传递给子组件一个值:p ...

  9. vue子组件改变父组件的值

    1 在父组件的coment绑定事件 <template> <div :class="classObj" class="app-wrapper" ...

随机推荐

  1. 吴裕雄--天生自然PYTHON爬虫:使用BeautifulSoup解析中国旅游网页数据

    import requests from bs4 import BeautifulSoup url = "http://www.cntour.cn/" strhtml = requ ...

  2. nodejs,webpack安装以及初步运用

    nodejs安装: 1.下载:https://nodejs.org/en/download/ 2.安装node-v6.11.3-x64.msi文件,直接默认安装(next……): 3.验证是否完成安装 ...

  3. kafka-console-consumer接收不到flume推送过来的消息

    原因和解决方法:需要先启动kafka,再启动flume,两者启动有先后顺序.

  4. 学习笔记:中国剩余定理(CRT)

    引入 常想起在空间里见过的一些智力题,这个题你见过吗: 一堆苹果,\(3\)个\(3\)个地取剩\(1\)个,\(5\)个\(5\)个地取剩\(1\)个,\(7\)个\(7\)个地取剩\(2\)个,苹 ...

  5. linux零散知识

    1.Linux的“| ”管道符用法 上一条命令的输出,作为下一条命令参数 方式:command1 | command2 Linux所提供的管道符“|”将两个命令隔开,管道符左边命令的输出就会作为管道符 ...

  6. 099、Java中String类之字符数组与字符串的转换

    01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...

  7. Git安装及基本配置

    一.在Linux上安装 1.Linux系统安装 使用Linux发布版包含的基础软件包管理工具可以很容易安装Git.例如,在Ubuntu系统上可使用以下指令安装Git: $ sudo apt-get i ...

  8. Paper代写:别让段落结尾拉低你的分数

    为了达到paper写作格式和字数要求,学生往往会在段末做一件事:总结.都不算是一个很长的段落.本来就写不了多少论证的内容,我们还强制加一个总结句,不仅占用了我们论证的篇幅,而且显得多余(段首的主题句已 ...

  9. mac java 装机清单

    1. JDK8 2. Eclipse IDE for Enterprise Java Developers 3. maven 4. Postman 5. VS Code 6. finalshell ( ...

  10. OKR-Periods of Words「POI 2006」

    题目描述 串是有限个小写字符的序列,特别的,一个空序列也可以是一个串.一个串 P 是串 A 的前缀,当且仅当存在串 B,使得 A = PB.如果 P != A 并且 P 不是一个空串,那么我们说 P  ...