亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue重要修飾符.sync對(duì)比v-model的區(qū)別及使用詳解

 更新時(shí)間:2022年07月26日 16:35:42   作者:前端新猿努力成長(zhǎng)  
這篇文章主要為大家介紹了Vue中重要修飾符.sync與v-model的區(qū)別對(duì)比及使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

Vue 中的雙向綁定

上一節(jié)中我們已經(jīng)討論過(guò)Vue中并沒(méi)有真正的雙向綁定。Vue中的 props等數(shù)據(jù)是單向流動(dòng)的,由父級(jí)至子級(jí)向下綁定的,即:每次父組件更新時(shí),子組件中的所有 props 都會(huì)刷新為最新的值。如果在子組件中修改 props ,Vue會(huì)向你發(fā)出一個(gè)警告,且并不能通過(guò)修改子組件的數(shù)據(jù)來(lái)更改父組件的數(shù)據(jù))。

如果有需求,我們可以在父組件中,子組件的標(biāo)簽上聲明一個(gè)監(jiān)聽(tīng)事件,在子組件想要修改數(shù)據(jù)時(shí)使用$emit觸發(fā)事件并傳入新的值,通知父組件進(jìn)行修改。這就可以實(shí)現(xiàn)某種程度上的雙向綁定。

真正的雙向綁定會(huì)帶來(lái)維護(hù)上的問(wèn)題,因?yàn)樽咏M件可以變更父組件,且在父組件和子組件兩側(cè)都沒(méi)有明顯的變更來(lái)源。Vue 團(tuán)隊(duì)推薦以 update:myPropName 的模式觸發(fā)事件取代直接修改的操作。這就用到了 .sync 修飾符。

Vue 中的 .syc 修飾符

自定義組件中,v-bind命令的 .sync 修飾符同 v-model 一樣,其實(shí)本質(zhì)上都是Vue的語(yǔ)法糖,用于實(shí)現(xiàn)父子組件間接的數(shù)據(jù)雙向綁。需要注意的一點(diǎn)是,Vue3 中已經(jīng)不再有 .sync 修飾符了,新的 v-model 取代了 Vue2 中的 v-model 和 .sync 修飾符。本文作為 Vue 入門(mén)的心得總結(jié),這里討論的是 Vue2中 的 .sync 修飾符。

一言以蔽之,v-bind命令的.sync 修飾符實(shí)質(zhì)就是父組件監(jiān)聽(tīng)子組件更新某個(gè)props的請(qǐng)求的縮寫(xiě)語(yǔ)法,一種語(yǔ)法糖。

如:

<Child v-bind:title.sync="title" />

完全等價(jià)于:

<Child
  v-bind:title="title"
  v-on:update:title="title = $event"
></Child>

與之配合,在子組件中,需要添加下面這段代碼來(lái)通知父組件對(duì)這個(gè)prop重新賦值:

this.$emit('update:title', newTitle)

這一個(gè) $emit 可以通過(guò)綁定事件觸發(fā),也可以使用 watch 監(jiān)聽(tīng)等方式來(lái)觸發(fā)。

此外,當(dāng)我們用一個(gè)對(duì)象 obj 同時(shí)設(shè)置多個(gè) prop 的時(shí)候,也可以將這個(gè) .sync 修飾符和 v-bind 配合使用:

<Son v-bind.sync="obj"></Son>
data(){
        return {
            obj:{read:true, name:'', title:'', length:''}
        }
    },

這樣會(huì)把 obj 對(duì)象中的每一個(gè) property (如 title) 都作為一個(gè)獨(dú)立的 prop 傳進(jìn)去,然后各自添加用于更新的 v-on 監(jiān)聽(tīng)器。

.sync 使用注意事項(xiàng)

需要注意,帶有 .sync 修飾符的 v-bind命令 不能 和表達(dá)式一起使用
(例如 :title.sync=”doc.title + ‘!’” 是無(wú)效的)。

你只能提供你想要綁定的 property 名,類(lèi)似 v-model。

另外還需要注意將 v-bind.sync 用在一個(gè)字面量的對(duì)象上,例如 v-bind.sync=”{ title: doc.title }”,是無(wú)法正常工作的,因?yàn)樵诮馕鲆粋€(gè)像這樣的復(fù)雜表達(dá)式的時(shí)候,有很多邊緣情況需要考慮。

.sync 與 v-model的比較

.sync 從功能上看和 v-model 十分相似,都是為了實(shí)現(xiàn)數(shù)據(jù)的“雙向綁定”,本質(zhì)上,也都不是真正的雙向綁定,而是語(yǔ)法糖,這是他們的相同之處。

但相比較之下,.sync 更加靈活,它可以在一個(gè)組件內(nèi)給多個(gè) prop 使用,而 v-model 在一個(gè)組件中只能有一個(gè) prop ,在 Vue2 中是這樣。

需要注意,Vue3中 v-model 已經(jīng)可以給多個(gè)prop使用了 

從語(yǔ)法的內(nèi)容來(lái)看,v-model 綁定的值和觸發(fā)的事件是較為固定的,根據(jù)不同類(lèi)型的特定組件有對(duì)應(yīng)的綁定值和事件,比如 input 組件,select 組件等表單組件,日期時(shí)間選擇組件,顏色選擇器組件等,這些組件所綁定的值使用 v-model 比較合適。

其他情況下,需要父子組件之間數(shù)據(jù)相互更新,還是使用 .sync.sync 針對(duì)更多的是各種的狀態(tài)變更,在父子組件之間互相傳遞,是一種 update 操作。

以上就是Vue重要修飾符.sync對(duì)比v-model的區(qū)別及使用詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue修飾符.sync v-model的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue學(xué)習(xí)之Vue-Router用法實(shí)例分析

    vue學(xué)習(xí)之Vue-Router用法實(shí)例分析

    這篇文章主要介紹了vue學(xué)習(xí)之Vue-Router用法,結(jié)合實(shí)例形式分析了Vue-Router路由原理與常見(jiàn)操作技巧,需要的朋友可以參考下
    2020-01-01
  • vue中@click綁定事件點(diǎn)擊不生效的原因及解決方案

    vue中@click綁定事件點(diǎn)擊不生效的原因及解決方案

    根據(jù)Vue2.0官方文檔關(guān)于父子組件通訊的原則,父組件通過(guò)prop傳遞數(shù)據(jù)給子組件,子組件觸發(fā)事件給父組件,這篇文章主要介紹了vue中@click綁定事件點(diǎn)擊不生效的解決方案,需要的朋友可以參考下
    2022-12-12
  • Vue中el-table條件渲染防止樣式亂掉(解決方法)

    Vue中el-table條件渲染防止樣式亂掉(解決方法)

    這篇文章主要介紹了Vue中el-table條件渲染防止樣式亂掉問(wèn)題,通過(guò)使用:key="Math.random()" 可解決樣式錯(cuò)亂問(wèn)題,此key屬性是vue自帶的特殊屬性,主要用在 Vue 的虛擬 DOM 算法,在新舊 nodes 對(duì)比時(shí)辨識(shí) VNodes,依次來(lái)提升頁(yè)面渲染性能,感興趣的朋友一起看看吧
    2023-11-11
  • vue 中 命名視圖的用法實(shí)例詳解

    vue 中 命名視圖的用法實(shí)例詳解

    這篇文章主要介紹了vue 中 命名視圖的用法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2019-08-08
  • 詳解vue.js的devtools安裝

    詳解vue.js的devtools安裝

    本篇文章主要介紹了詳解vue.js的devtools安裝 ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • 基于 vue-skeleton-webpack-plugin 的骨架屏實(shí)戰(zhàn)

    基于 vue-skeleton-webpack-plugin 的骨架屏實(shí)戰(zhàn)

    這篇文章主要介紹了基于 vue-skeleton-webpack-plugin 的骨架屏實(shí)戰(zhàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • vue v-on監(jiān)聽(tīng)事件詳解

    vue v-on監(jiān)聽(tīng)事件詳解

    這篇文章主要為大家詳細(xì)介紹了vue v-on監(jiān)聽(tīng)事件的相關(guān)資料,Vue.js中的監(jiān)聽(tīng)事件是如何處理的,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • vue框架實(shí)現(xiàn)將側(cè)邊欄完全隱藏

    vue框架實(shí)現(xiàn)將側(cè)邊欄完全隱藏

    這篇文章主要介紹了vue框架實(shí)現(xiàn)將側(cè)邊欄完全隱藏,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue實(shí)現(xiàn)垂直無(wú)限滑動(dòng)日歷組件

    vue實(shí)現(xiàn)垂直無(wú)限滑動(dòng)日歷組件

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)垂直無(wú)限滑動(dòng)日歷組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vue頁(yè)面堆棧管理器詳情

    Vue頁(yè)面堆棧管理器詳情

    這篇文章主要介紹了Vue頁(yè)面堆棧管理器
    2021-10-10

最新評(píng)論