首页 > 其他 > 详细

react学习教程入门五(组件三大核心属性之props)

时间:2021-03-04 12:08:26      阅读:15      评论:0      收藏:0      [点我收藏+]

前面我们说过state属性,这节我们要讲的是props属性,state 和 props 主要的区别在于 props是只读的,不可变的,而 state 可以根据与用户交互来改变。这就是为什么有些容器组件需要定义 state 来更新和修改数据。 而子组件只能通过 props 来传递数据。以下示例中,我们定义了两个容器div来,用来渲染Person组件,参数通过在组件后跟上传递过来的参数,类似于<Person name="老刘" age={18} sex="女"/>,代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>props使用</title>
</head>
<body>
    <!-- 准备好一个“容器” -->
    <div id="test1"></div>
    <div id="test2"></div>
    
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <!-- 引入react-dom,用于支持react操作DOM -->
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <!-- 引入babel,用于将jsx转为js -->
    <script type="text/javascript" src="../js/babel.min.js"></script>

    <script type="text/babel">
        //创建组件
        class Person extends React.Component{
            render(){
                // console.log(this);
                const {name,age,sex} = this.props
                return (
                    <ul>
                        <li>姓名:{name}</li>
                        <li>性别:{sex}</li>
                        <li>年龄:{age+1}</li>
                    </ul>
                )
            }
        }
        const p = {name:‘老刘‘,age:18,sex:‘女‘}
        // console.log(‘@‘,...p);
        //渲染组件到页面
        ReactDOM.render(<Person name={p.name} age={p.age} sex={p.sex}/>,document.getElementById(‘test1‘))
        ReactDOM.render(<Person {...p}/>,document.getElementById(‘test2‘))
    </script>
</body>
</html>

 这个是props的基本使用,那么如果你想对传递的参数进行限制和类型判断则需要引入prop-types.js;比如以上的这个示例,如果要对Person组件中的属性进行类型限制,可以通过Person.propTypes方式来限制,如:

Person.propTypes = {
            name:PropTypes.string.isRequired, //限制name必传,且为字符串
            sex:PropTypes.string,//限制sex为字符串
            age:PropTypes.number,//限制age为数值
            speak:PropTypes.func,//限制speak为函数
        }

如果你要对Person组件要进行默认标签属性进行设置,则通过Person.defaultProps来默认设置,如:

//指定默认标签属性值
        Person.defaultProps = {
            sex:‘男‘,//sex默认值为男
            age:18 //age默认值为18
        }

这样的话,我如果传递参数类型错误或者必传的没传,则会报错,报错信息类似:Warning: Failed prop type: Invalid prop `xxx` of type `number` supplied to `Xxx`, expected `string`.表达的意思是要你传的xxx的属性必须为number类型的,但是你传了一个string类型的参数。完整实例代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>对props进行限制</title>
</head>
<body>
    <!-- 准备好一个“容器” -->
    <div id="test1"></div>
    <div id="test2"></div>
    <div id="test3"></div>
    
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <!-- 引入react-dom,用于支持react操作DOM -->
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <!-- 引入babel,用于将jsx转为js -->
    <script type="text/javascript" src="../js/babel.min.js"></script>
    <!-- 引入prop-types,用于对组件标签属性进行限制 -->
    <script type="text/javascript" src="../js/prop-types.js"></script>

    <script type="text/babel">
        //创建组件
        class Person extends React.Component{
            render(){
                // console.log(this);
                const {name,age,sex} = this.props
                //props是只读的
                //this.props.name = ‘jack‘ //此行代码会报错,因为props是只读的
                return (
                    <ul>
                        <li>姓名:{name}</li>
                        <li>性别:{sex}</li>
                        <li>年龄:{age+1}</li>
                    </ul>
                )
            }
        }
        //对标签属性进行类型、必要性的限制
        Person.propTypes = {
            name:PropTypes.string.isRequired, //限制name必传,且为字符串
            sex:PropTypes.string,//限制sex为字符串
            age:PropTypes.number,//限制age为数值
            speak:PropTypes.func,//限制speak为函数
        }
        //指定默认标签属性值
        Person.defaultProps = {
            sex:‘男‘,//sex默认值为男
            age:18 //age默认值为18
        }
        //渲染组件到页面
        ReactDOM.render(<Person name={100} speak={speak}/>,document.getElementById(‘test1‘))
        ReactDOM.render(<Person name="tom" age={18} sex="女"/>,document.getElementById(‘test2‘))

        const p = {name:‘老刘‘,age:18,sex:‘女‘}
        // console.log(‘@‘,...p);
        // ReactDOM.render(<Person name={p.name} age={p.age} sex={p.sex}/>,document.getElementById(‘test3‘))
        ReactDOM.render(<Person {...p}/>,document.getElementById(‘test3‘))

        function speak(){
            console.log(‘我说话了‘);
        }
    </script>
</body>
</html>

 

react学习教程入门五(组件三大核心属性之props)

原文:https://www.cnblogs.com/xfly-lin/p/14479319.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!