React中Props的详细使用和props的校验

简介: React中Props的详细使用和props的校验

props中的children属性

组件标签只用有子节点的时候,props就会有该属性;
children的属性跟props一样的,值可以是任意值;(文本,React元素,组件,函数)
组件: <ClassCom> 传递的数据  </ClassCom>
这样的组件标签中就会有子节点

props中的children的简单使用

<!-- 主页面 -->
import React from 'react';
import ReactDOM from 'react-dom'; 
import ClassCom from "./components/ClassCom"
ReactDOM.render(<ClassCom>传递的数据</ClassCom>,document.getElementById('root'))
子组件
import React from "react";
// 函数组件
// const ClassCom = (props) => {
//     return (
//         <div>
//             <h2>组件</h2>
//             { props.children }
//         </div>
//     )
// }
// 类组件
class ClassCom extends React.Component{
    render() { 
        return (
            <div>
                <p>-------我是子组件--------</p>
                {this.props.children}
            </div>
        )
    }
}
export default ClassCom

props中children的属性是标签

<!-- 主页面 -->
import React from 'react'; //这个是react这个包,我们是需要的
import ReactDOM from 'react-dom'; //这个是react的虚拟dom
import ClassCom from "./components/ClassCom"
ReactDOM.render(<ClassCom>
  <p>我是一个p标签</p>
</ClassCom>, document.getElementById('root'))
<!-- 子组件 -->
import React from "react";
// 类组件
class ClassCom extends React.Component{
    render() { 
        return (
            <div>
                <p>-------我是子组件--------</p>
                {this.props.children}
            </div>
        )
    }
}
export default ClassCom

props的校验

为什么会有props的校验。因为props是外来的。
我们无法保证使用者传递过来的参数是什么格式的。
如果我们这个props是数组,而使用者传递的是数字。
这个时候会出现意想不到的后果。
所以我们需要对props进行校验,如props的类型,格式。

校验步骤

1.需要安装一个包 yarn add prop-types 或者 npm i prop-types
2.导包 import PropTypes from 'prop-types'
3. 组件名.PropTypes = { 属性:PropTypes.类型 }

PropTypes的类型有

PropTypes.array    数组
PropTypes.bool     布尔
PropTypes.func     函数
PropTypes.number
PropTypes.object
PropTypes.string

props校验的简单使用

//组件
import React from "react";
// 导包
import PropTypes from 'prop-types'
// 类组件
class ClassCom extends React.Component{
    render() { 
        return (
            <div>
                {
                    this.props.arr.map(item => <li key={item.id }> { item.name}</li>)
                }
                 数字: {this.props.num }
            </div>
        )
    }
}
ClassCom.propTypes  = {
    // 希望传递过来的arr是数组
    arr: PropTypes.array,
    num:PropTypes.number
}
export default ClassCom

当传递的数据不符合条件的时候

import React from 'react'; 
import ReactDOM from 'react-dom';
import ClassCom from "./components/ClassCom"
const list = [{name:'李大为',id:1},{name:'夏洁',id:2}]
ReactDOM.render(<ClassCom arr={list} num={100}></ClassCom>, document.getElementById('root'))

Props的约束规则

// num属性是必填写的
num: PropTypes.number.isRequired,
// 特定结果的对象
myObj: PropTypes.shape({
    name: PropTypes.string,
    age: PropTypes.number,
    sex:PropTypes.bool
})
// 表示是一个React元素
tag:PropTypes.element

Props的默认值的设置

// ClassCom是组件名称
ClassCom.defaultProps = {
    pageSize:10
}
使用的时候 页数: { this.props.pageSize}

Props限制的简单使用

import React from 'react';
import ReactDOM from 'react-dom'; 
import ClassCom from "./components/ClassCom"
const list = [{ name: '李大为', id: 1 }, { name: '夏洁', id: 2 }]
const obj = {
  name: 123, //这个类型不正确
  sex: '男',
  age:18
}
ReactDOM.render(<ClassCom arr={list} num={100} myObj={ obj}></ClassCom>, document.getElementById('root'))
import React from "react";
// 导包
import PropTypes from 'prop-types'
// 类组件
class ClassCom extends React.Component{
    render() { 
        return (
            <div>
                {
                    this.props.arr.map(item => <li key={item.id }> { item.name}</li>)
                }
                数字: {this.props.num}
                页数 { this.props.pageSize}
            </div>
        )
    }
}
ClassCom.propTypes  = {
    // 希望传递过来的arr是数组
    arr: PropTypes.array,
    // num属性是必填写的
    num: PropTypes.number.isRequired,
    // 特定结果的对象
    myObj: PropTypes.shape({
        name: PropTypes.string,
        age: PropTypes.number,
        sex:PropTypes.bool
    }),
    // 表示是一个React元素
    tag: PropTypes.element
}
<!-- 这是默认值 -->
ClassCom.defaultProps = {
    pageSize:10
}
export default ClassCom

遇见问题,这是你成长的机会,如果你能够解决,这就是收获。

相关文章
|
2月前
|
前端开发 JavaScript
react学习(13)props
react学习(13)props
|
3月前
|
前端开发
React函数式组件props的使用(六)
【8月更文挑战第14天】React函数式组件props的使用(六)
53 1
React函数式组件props的使用(六)
|
2月前
|
前端开发
学习react基础(2)_props、state和style的使用
本文介绍了React中组件间数据传递的方式,包括props和state的使用,以及如何在React组件中使用style样式。
31 0
|
2月前
|
前端开发
React添加路径别名alias、接受props默认值、并二次封装antd中Modal组件与使用
本文介绍了在React项目中如何添加路径别名alias以简化模块引入路径,设置组件props的默认值,以及如何二次封装Ant Design的Modal组件。文章还提供了具体的代码示例,包括配置Webpack的alias、设置defaultProps以及封装Modal组件的步骤和方法。
66 1
React添加路径别名alias、接受props默认值、并二次封装antd中Modal组件与使用
|
2月前
|
前端开发 JavaScript
React配合axios请求拦截校验session,403跳转至登陆页面
React中使用axios进行请求拦截,通过自定义事件监听和响应拦截实现403状态码时的自动登录页面跳转。
73 2
|
1月前
|
前端开发 JavaScript CDN
React Props
10月更文挑战第8天
11 0
|
2月前
|
前端开发 数据安全/隐私保护
react antd 实现修改密码(原密码,新密码,再次输入新密码,新密码增加正则复杂度校验)
文章介绍了如何在React项目中使用Ant Design实现一个修改密码的组件,包括原密码、新密码和再次输入新密码的表单项,并为新密码增加了正则表达式复杂度校验。
67 0
react antd 实现修改密码(原密码,新密码,再次输入新密码,新密码增加正则复杂度校验)
|
2月前
|
前端开发
react学习(15)函数式组件中使用props
react学习(15)函数式组件中使用props
|
2月前
|
前端开发
react学习(14)类式组件的构造器与props
react学习(14)类式组件的构造器与props
|
2月前
|
前端开发 JavaScript
React 中的 props 属性传递技巧
【9月更文挑战第6天】本文详细介绍了React中`props`的基本用法,包括传递基本数据类型、对象和数组。文章通过多个代码示例展示了如何正确使用`props`,并探讨了常见的问题及解决方法,如`props`不可变性、默认值设置及类型检查等。正确掌握这些技巧有助于提升编程效率,编写出更健壮的代码。
57 13