zoukankan      html  css  js  c++  java
  • (四)React组件的三大特性 Props

    React组件的三大特性 Props

    复习三点运算符:
    常用的就是
       展开数组 合并数组
       不能单独展开对象 但是可以合并对象{...person,name:'jack',address:"地球"}
       在函数中使用进行单独的传值

    <script type="text/javascript" >
        	 //在数组中使用
                let arr1 = [1,3,5,7,9]
                let arr2 = [2,4,6,8,10]
                console.log(...arr1); //展开一个数组
                let arr3 = [...arr1,...arr2]//连接数组 都展开放进去
                
                //在函数中使用
                function sum(...numbers){
                    return numbers.reduce((preValue,currentValue)=>{
                        return preValue + currentValue
                    })
                }
                console.log(sum(1,2,3,4));
                //构造字面量对象时使用展开语法
                let person = {name:'tom',age:18}
                let person2 = {...person}
                //console.log(...person); //报错,展开运算符不能展开对象
                person.name = 'jerry'
                console.log(person2);
                console.log(person);
                //合并
                let person3 = {...person,name:'jack',address:"地球"}
                console.log(person3);
                
            </script>
    

    props的基本使用:

    这是组件的基本使用方式,在渲染组件的时候,通过标签属性传值的方式传值,

    //创建组件
            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>
                    )
                }
            }
            //渲染组件到页面
            ReactDOM.render(<Person name="jerry" age={19}  sex="男"/>,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'))
    

    限制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 (
                        <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('我说话了');
            }
    

    简写方式 在构造器中是否使用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 (
                        <ul>
                            <li>姓名:{name}</li>
                            <li>性别:{sex}</li>
                            <li>年龄:{age+1}</li>
                        </ul>
                    )
                }
            }
            //渲染组件到页面
            ReactDOM.render(<Person name="jerry"/>,document.getElementById('test1'))
    

    函数式组件使用 props ( 因为function 没有this 可是实例化的内容 所有不能使用 state 和 rerfs 这两个属性 但是作为声明组件而言 是可以接收props)

       //创建组件
            function Person (props){
                const {name,age,sex} = props
                return (
                        <ul>
                            <li>姓名:{name}</li>
                            <li>性别:{sex}</li>
                            <li>年龄:{age}</li>
                        </ul>
                    )
            }
            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(<Person name="jerry"/>,document.getElementById('test1'))
    
    咫尺远近却无法靠近的那个你,才敢让你发觉你并不孤寂
  • 相关阅读:
    ubuntu英文环境下使用中文输入法
    Flex 调用添加了SoapHeader的web service
    RoR: Ruby On Rails Web Service 3 分发模式
    C# CRC8实现
    java正则表达式过滤html标签
    静态内部类和非静态内部类的区别
    Java反射机制
    java回调函数简介
    Java之泛型编程
    Java基础知识之系统命令调用、序列化、JDO、匿名内部类
  • 原文地址:https://www.cnblogs.com/tcz1018/p/15405840.html
Copyright © 2011-2022 走看看