本文小編為大家詳細(xì)介紹“vue實(shí)現(xiàn)雙向綁定的方法有哪些”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“vue實(shí)現(xiàn)雙向綁定的方法有哪些”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。
成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比六枝網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式六枝網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋六枝地區(qū)。費(fèi)用合理售后完善,10余年實(shí)體公司更值得信賴。
vue實(shí)現(xiàn)雙向綁定的方法:1、利用v-model指令實(shí)現(xiàn)綁定,自定義組件上的v-model相當(dāng)于傳遞了modelValue prop并接收拋出的update:modelValue事件;2、利用vue-better-sync插件實(shí)現(xiàn)綁定;3、利用v-bind.sync修飾符,語法“<ChildComponent :title.sync="pageTitle" />”。
<ChildComponent v-model="pageTitle" />
<!-- 是以下的簡寫: -->
<ChildComponent :value="pageTitle" @input="pageTitle = $event" />
如果要將屬性或事件名稱更改為其他名稱,則需要在 ChildComponent 組件中添加 model
選項(xiàng):
<!-- ParentComponent.vue -->
<ChildComponent v-model="pageTitle" />
// ChildComponent.vue
export default {
model: {
prop: 'title',
event: 'change'
},
props: {
// 這將允許 `value` 屬性用于其他用途
value: String,
// 使用 `title` 代替 `value` 作為 model 的 prop
title: {
type: String,
default: 'Default title'
}
}
}
所以,在這個例子中 v-model 是以下的簡寫:
<ChildComponent :title="pageTitle" @change="pageTitle = $event" />
在 Vue 3.x中,自定義組件上的 v-model 相當(dāng)于傳遞了 modelValue prop
并接收拋出的 update:modelValue
事件:
<ChildComponent v-model="pageTitle" />
<!-- 是以下的簡寫: -->
<ChildComponent
:modelValue="pageTitle"
@update:modelValue="pageTitle = $event"
/>
Vue3
可以綁定多個v-model
, 例如:<ChildComponent v-model:title="pageTitle" v-model:name="pageName" />
有需求如此:開發(fā)一個 Prompt 組件,要求同步用戶的輸入,點(diǎn)擊按鈕可關(guān)閉彈窗。
一般我們會這樣做:
<template>
<div v-show="_visible">
<div>完善個人信息</div>
<div>
<div>尊姓大名?</div>
<input v-model="_answer" />
</div>
<div>
<button @click="_visible = !_visible">確認(rèn)</button>
<button @click="_visible = !_visible">取消</button>
</div>
</div>
</template>
<script>
export default {
name: 'prompt',
props: {
answer: String,
visible: Boolean
},
computed: {
_answer: {
get() {
return this.answer
},
set(value) {
this.$emit('input', value)
}
},
_visible: {
get() {
return this.visible
},
set(value) {
this.$emit('update:visible', value)
}
}
}
}
</script>
寫一兩個組件還好,組件規(guī)模一旦擴(kuò)大,寫雙向綁定真能寫出毛病來。于是,為了解放生產(chǎn)力,有了 vue-better-sync 這個輪子,且看用它如何改造我們的 Prompt 組件:
<template>
<div v-show="actualVisible">
<div>完善個人信息</div>
<div>
<div>尊姓大名?</div>
<input v-model="actualAnswer" />
</div>
<div>
<button @click="syncVisible(!actualVisible)">確認(rèn)</button>
<button @click="syncVisible(!actualVisible)">取消</button>
</div>
</div>
</template>
<script>
import VueBetterSync from 'vue-better-sync'
export default {
name: 'prompt',
mixins: [
VueBetterSync({
prop: 'answer', // 設(shè)置 v-model 的 prop
event: 'input' // 設(shè)置 v-model 的 event
})
],
props: {
answer: String,
visible: {
type: Boolean,
sync: true // visible 屬性可用 .sync 雙向綁定
}
}
}
</script>
vue-better-sync 統(tǒng)一了 v-model 和 .sync 傳遞數(shù)據(jù)的方式,你只需 this.actual${PropName} = newValue 或者 this.sync${PropName}(newValue) 即可將新數(shù)據(jù)傳遞給父組件。
GitHub:fjc0k/vue-better-sync
在某些情況下,我們可能需要對某一個 prop
進(jìn)行“雙向綁定”(除了前面用 v-model 綁定 prop 的情況)。為此,我們建議使用 update:myPropName
拋出事件。例如,對于在上一個示例中帶有 title prop 的 ChildComponent,我們可以通過下面的方式將分配新 value 的意圖傳達(dá)給父級:
this.$emit('update:title', newValue)
如果需要的話,父級可以監(jiān)聽該事件并更新本地 data property。例如:
<ChildComponent :title="pageTitle" @update:title="pageTitle = $event" />
為了方便起見,我們可以使用 .sync 修飾符來縮寫,如下所示:
<ChildComponent :title.sync="pageTitle" />
讀到這里,這篇“vue實(shí)現(xiàn)雙向綁定的方法有哪些”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點(diǎn)還需要大家自己動手實(shí)踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
分享標(biāo)題:vue實(shí)現(xiàn)雙向綁定的方法有哪些
網(wǎng)頁鏈接:http://muchs.cn/article6/pdjpog.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站維護(hù)、品牌網(wǎng)站設(shè)計、面包屑導(dǎo)航、網(wǎng)站設(shè)計公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)