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