React三大属性之props的使用详解

2022-04-15 0 735
目录
  • 类组件
  • 函数组件
    • props是只读的
  • 组件间通信

    上期讲了state,接下来讲讲props。props功能在于组件间通信(父子组件),首先说说在各种组件中的用法:

    类组件

    //父组件传值
    class Father extends React.PureComponent{
        render(){
            return (
                <Son value={"son"} />
            )
        }
    }
    
    class Son extends React.PureComponent{
        render(){
            return (
                <div>this data is {this.props.value}</div>
            )
        }
    }
    

    函数组件

    function Fa(){
        return (
            <Son value={"son"} />
        )
    }
    
    function Son(props){
        return (
            <div>this data is {props.value}</div>
        )
    }
    

    在函数组件中,props只需要传一个值就好了,非常方便 在React文档中,对props的解释是

    当 React 元素为用户自定义组件时,它会将 JSX 所接收的属性(attributes)以及子组件(children)转换为单个对象传递给组件,这个对象被称之为 “props”

    所以,我们通过props能得到父类组件上传的值,也能通过props.children直接得到jsx写成的子组件

    props是只读的

    React在文档中强调

    所有 React 组件都必须像纯函数一样保护它们的 props 不被更改。

    纯函数的概念我们已经在redux中解释过了,总而言之,我们不能改变props的值。

    组件间通信

    现在来总结一下组件间通信:

    • props 首先上一个类组件的写法:
    //父组件给子组件传值以及说过了,现在总结子组件给父组件传值,此时往往需要父组件给子组件先传一个props函数,子组件通过调用传入的函数传值改变父组件的值
    export default class Fa extends Component {
        state = {faValue:'Fa1'}
    
        changeFa = (value)=>{
            this.setState(()=>{
                return {faValue:value}
            })
        }
        render() {
            return (
                <>
                    <h1>Fa's value is {this.state.faValue}</h1>
                    <Son changeFa={this.changeFa}/>
                </>
            )
        }
    }
    
    export default class Son extends React.PureComponent{
    
        changeValue = ()=>{
            this.props.changeFa(this.inputRef.value)
        }
        render() {
            return (
                <>
                    <input type="text" placeholder={"请输入您的值"} ref={(el)=>{this.inputRef = el}}/>
                    <button onClick={this.changeValue}>change</button>
                </>
            )
        }
    }
    

    然后写一个函数组件的写法:

    function Fa(){
        const [faValue,setFaValue] = useState("Fa1")
    
        const changeFa = (value)=>{
            setFaValue(value)
        }
        return (
            <div>
                <h1>Fa's value is {faValue}</h1>
                <Son changeFa={changeFa} />
            </div>
        )
    }
    
    function Son(props){
        const inputValue = useRef("")
            //定义改变fa组件的值的函数
            const changeFaValue = ()=>{
                props.changeFa(inputValue.current.value)
            }
            return (
                <>
                    <input type="text" placeholder={"请输入您要改变的值"} ref={inputValue}/>
                    <button onClick={changeFaValue}>change value</button>
                </>
            )
    }
    
    • eventbus(订阅-发布机制)

    这个可以理解为弱化的redux。这边我们用库pubsub-js来写。写法如下:

    //比如针对之前的输入案例,我需要给兄弟组件传一个值value,如果不用props,我们该怎么写
    Bro:
    export default class Bro extends Component {
    
        componentDidMount() {
            this.sonData =  PubSub.subscribe("brother",(msg,data)=>{
                console.log("Bro Component have recived the msg",data);
            })
        }
    
        componentWillUnmount() {
            PubSub.unsubscribe(this.sonData)
        }
    
        render() {
            return (
                <>
                    <div>brother</div>
                </>
            )
        }
    }
    Son:
    export default class Son extends React.PureComponent{
    
        changeValue = ()=>{
            PubSub.publish("brother",this.inputRef.value)
        }
    
        render() {
            return (
                <>
                    <input type="text" placeholder={"请输入您的值"} ref={(el)=>{this.inputRef = el}}/>
                    <button onClick={this.changeValue}>change</button>
                </>
            )
        }
    }
    

    这个方法常用的就是三个api,第一个subscribe,发布的相应的事件,并且定义事件要做什么事。第二个是publish,订阅发布的事情,并且传入相应要改变的值。第三个是unsubscribe用来取消发布的事情,做内存的优化

    以上就是React三大属性之props的使用详解的详细内容,更多关于React三大属性之props的资料请关注NICE源码其它相关文章!

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 JavaScript React三大属性之props的使用详解 https://www.niceym.com/33244.html