20200430 Vue組件--單向數(shù)據(jù)流--props 的兩種應用場景

單向數(shù)據(jù)流中props的兩種應用場景

  • 單向數(shù)據(jù)流:通過 props 傳遞數(shù)據(jù)是單向的,也就是父組件數(shù)據(jù)變化時會傳遞給子組件,但是反過來不行
  • 單向數(shù)據(jù)流的目的:是盡可能的將父子組件解耦,避子組件無意中修改了父組件的狀態(tài)。
  • 單向數(shù)據(jù)流的應用場景:業(yè)務中會經(jīng)常遇到兩種需要改變 prop 的情況

第一種:

父組件傳遞初始值進來,子組件將它作為初始值保存起來,在自己的作用域下可以隨意使用和修改。這種情況可以在組件 data 內(nèi)再聲明一個數(shù)據(jù),引用父組件的 prop。
步驟一:注冊一個組件
步驟二:將父組件的數(shù)據(jù)傳遞進來,并在子組件中使用 props 接收
步驟三:將傳遞進來的數(shù)據(jù)通過初始值保存起來。

        Vue.component('my-component', {
            props: ['msg'],
            template: '<div>{{count}}</div>',
            data() {
                return {
                    count: this.msg //步驟三:將傳遞進來的數(shù)據(jù)通過初始值保存起來。
                }
            }
        })

第二種:

prop 作為需要被轉變的原始值傳入,這種情況使用計算屬性就可以了
步驟一:注冊組件
步驟二:將父組件的數(shù)據(jù)傳遞進來,并在子組件中用 props 接收
步驟三:將傳遞進來的數(shù)據(jù)通過計算屬性進行重新計算

//在input中輸入數(shù)字,改變div的高度為相應的大小
        <input type="text" v-model="height">
        <width-component :height="height"></width-component>


        Vue.component('width-component', {
            props: ['height'],
            template: '<div :style="style"></div>',
            data() {
                return {
                }
            },
            computed: { 
                style() {
                    return {
                        height: this.height + 'px',
                        background: 'red',
                        width: '30px'
                    }
                }
            }
        })
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

友情鏈接更多精彩內(nèi)容