下面我就為大家分享一篇vue元件傳遞物件中實現單向綁定的範例,具有很好的參考價值,希望對大家有所幫助。
當使用vue組件時,組件之間經常需要傳遞數據,這裡不討論傳遞一個字符串變量或者數字變量的情況,那些去看官方文檔就夠了,此處提出我在組件間傳遞物件時遇到的一個坑。
當元件間傳遞物件時,由於此物件的參考類型指向的都是一個位址,所以在子元件中修改物件的某個屬性值,父元件中的物件對應的屬性也會隨之改變,如果有這種雙向綁定的需要,那麼這也算一種不錯的辦法,但如果不需要這種雙向綁定,那就要定義一個新的對象來複製原對象的屬性和值,坑就在這裡,假如你普通的var、let 一個對象,例如:
computed: { data: function () { let obj={}; obj=this.message//this.message是父组件传递的对象 return obj } },
將data中各屬性分別綁定到輸入框中,並修改試試,你會發現父組件中對應的屬性值還是會改變,並沒有實現單向綁定的效果,這時就需要加一個方法了
computed: { data: function () { let obj=Object.assign({}, this.message); return obj } },
這樣返回的data就是一個新的對象,並不會指向原對象的地址,所以再對其進行修改就不會對父元件中的物件造成影響了。
上面是我整理給大家的,希望今後對大家有幫助。
相關文章:
#以上是在vue元件傳遞物件中實作單向綁定,該怎麼做?的詳細內容。更多資訊請關注PHP中文網其他相關文章!