前面我们说过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