(四)React组件的三大特性 Props
React组件的三大特性 Props
复习三点运算符:
常用的就是
?? 展开数组 合并数组
?? 不能单独展开对象 但是可以合并对象{...person,name:'jack',address:"地球"}
?? 在函数中使用进行单独的传值
props的基本使用:
这是组件的基本使用方式,在渲染组件的时候,通过标签属性传值的方式传值,
//创建组件
class Person extends React.Component{
render(){
// console.log(this);
const {name,age,sex} = this.props
return (
- 姓名:{name}
- 性别:{sex}
- 年龄:{age+1}
)
}
}
//渲染组件到页面
ReactDOM.render( ,document.getElementById('test1'))
ReactDOM.render( ,document.getElementById('test2'))
const p = {name:'老刘',age:18,sex:'女'}
// console.log('@',...p);
// ReactDOM.render(,document.getElementById('test3'))
ReactDOM.render( ,document.getElementById('test3'))
限制props的类型 默认值
如果出现与传值不符 控制台会弹出警告
使用 propTypes 进行限制
使用 defaultProps 设置默认值
//创建组件
class Person extends React.Component{
render(){
// console.log(this);
const {name,age,sex} = this.props
//props是只读的
//this.props.name = 'jack' //此行代码会报错,因为props是只读的
return (
- 姓名:{name}
- 性别:{sex}
- 年龄:{age+1}
)
}
}
//对标签属性进行类型、必要性的限制
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(,document.getElementById('test1'))
ReactDOM.render( ,document.getElementById('test2'))
const p = {name:'老刘',age:18,sex:'女'}
// console.log('@',...p);
// ReactDOM.render(,document.getElementById('test3'))
ReactDOM.render( ,document.getElementById('test3'))
function speak(){
console.log('我说话了');
}
简写方式 在构造器中是否使用this指向props
//创建组件
class Person extends React.Component{
constructor(props){
//构造器是否接收props,是否传递给super,取决于:是否希望在构造器中通过this访问props
// console.log(props);
super(props)
console.log('constructor',this.props);
}
//对标签属性进行类型、必要性的限制
static propTypes = {
name:PropTypes.string.isRequired, //限制name必传,且为字符串
sex:PropTypes.string,//限制sex为字符串
age:PropTypes.number,//限制age为数值
}
//指定默认标签属性值
static defaultProps = {
sex:'男',//sex默认值为男
age:18 //age默认值为18
}
render(){
// console.log(this);
const {name,age,sex} = this.props
//props是只读的
//this.props.name = 'jack' //此行代码会报错,因为props是只读的
return (
- 姓名:{name}
- 性别:{sex}
- 年龄:{age+1}
)
}
}
//渲染组件到页面
ReactDOM.render( ,document.getElementById('test1'))
函数式组件使用 props ( 因为function 没有this 可是实例化的内容 所有不能使用 state 和 rerfs 这两个属性 但是作为声明组件而言 是可以接收props)
//创建组件
function Person (props){
const {name,age,sex} = props
return (
- 姓名:{name}
- 性别:{sex}
- 年龄:{age}
)
}
Person.propTypes = {
name:PropTypes.string.isRequired, //限制name必传,且为字符串
sex:PropTypes.string,//限制sex为字符串
age:PropTypes.number,//限制age为数值
}
//指定默认标签属性值
Person.defaultProps = {
sex:'男',//sex默认值为男
age:18 //age默认值为18
}
//渲染组件到页面
ReactDOM.render( ,document.getElementById('test1'))