Vue 實(shí)現(xiàn)雙向綁定的四種方法
1. v-model 指令
<input v-model="text" />
上例不過是一個(gè)語法糖,展開來是:
<input :value="text" @input="e => text = e.target.value" />
2. .sync 修飾符
<my-dialog :visible.sync="dialogVisible" />
這也是一個(gè)語法糖,剝開來是:
<my-dialog :visible="dialogVisible" @update:visible="newVisible => dialogVisible = newVisible" />
my-dialog 組件在 visible 變化時(shí) this.$emit('update:visible', newVisible) 即可。
3. model 屬性 (JSX/渲染函數(shù)中)
Vue 在 2.2.0 版本以后,允許自定義組件的 v-model ,這就導(dǎo)致在 JSX / 渲染函數(shù)中實(shí)現(xiàn) v-model 時(shí)得考慮組件的不同配置,不能一律如此(假使 my-dialog 組件的 model 為 { prop: 'visible', event: 'change' } ):
{
render(h) {
return h('my-dialog', {
props: { value: this.dialogVisible },
on: { input: newVisible => this.dialogVisible = newVisible }
})
}
}
而應(yīng)如此:
{
render(h) {
return h('my-dialog', {
props: { visible: this.dialogVisible },
on: { change: newVisible => this.dialogVisible = newVisible }
})
}
}
然而,利用 model 屬性,完全可以做到不用管它 prop 、 event 的目的:
{
render(h) {
return h('my-dialog', {
model: {
value: this.dialogVisible,
callback: newVisible => this.dialogVisible = newVisible
}
})
}
}
JSX 中這樣使用:
{
render() {
return (
<my-dialog
{...{
model: {
value: this.dialogVisible,
callback: newVisible => this.dialogVisible = newVisible
}
}}
/>
)
}
}
4. vue-better-sync 插件
有需求如此:開發(fā)一個(gè) Prompt 組件,要求同步用戶的輸入,點(diǎn)擊按鈕可關(guān)閉彈窗。

一般我們會(huì)這樣做:
<template>
<div v-show="_visible">
<div>完善個(gè)人信息</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>
寫一兩個(gè)組件還好,組件規(guī)模一旦擴(kuò)大,寫雙向綁定真能寫出毛病來。于是,為了解放生產(chǎn)力,有了 vue-better-sync 這個(gè)輪子,且看用它如何改造我們的 Prompt 組件:
<template>
<div v-show="actualVisible">
<div>完善個(gè)人信息</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
總結(jié)
以上所述是小編給大家介紹的Vue 實(shí)現(xiàn)雙向綁定的四種方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- Vue2實(shí)現(xiàn)組件props雙向綁定
- vue.js數(shù)據(jù)綁定的方法(單向、雙向和一次性綁定)
- 深入理解vue.js雙向綁定的實(shí)現(xiàn)原理
- Vue2.0利用 v-model 實(shí)現(xiàn)組件props雙向綁定的優(yōu)美解決方案
- Vuejs第一篇之入門教程詳解(單向綁定、雙向綁定、列表渲染、響應(yīng)函數(shù))
- Vue父子組件雙向綁定傳值的實(shí)現(xiàn)方法
- Vue.js每天必學(xué)之?dāng)?shù)據(jù)雙向綁定
- Vue.js實(shí)現(xiàn)雙向數(shù)據(jù)綁定方法(表單自動(dòng)賦值、表單自動(dòng)取值)
- Angular和Vue雙向數(shù)據(jù)綁定的實(shí)現(xiàn)原理(重點(diǎn)是vue的雙向綁定)
- Vue2.x和Vue3.x的雙向綁定原理詳解
相關(guān)文章
利用Vue Router實(shí)現(xiàn)單頁(yè)面應(yīng)用(SPA)的代碼示例
在當(dāng)今前端開發(fā)中,單頁(yè)面應(yīng)用(SPA)已成為一種主流的開發(fā)模式,它通過在用戶與網(wǎng)頁(yè)之間提供更流暢的交互體驗(yàn),來改變傳統(tǒng)多頁(yè)面應(yīng)用的思維,本文將詳細(xì)介紹如何利用 Vue.js 中的 Vue Router 來實(shí)現(xiàn)一個(gè)簡(jiǎn)單的單頁(yè)面應(yīng)用,需要的朋友可以參考下2025-01-01
vue實(shí)現(xiàn)垂直無限滑動(dòng)日歷組件
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)垂直無限滑動(dòng)日歷組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
vuecli3打包后出現(xiàn)跨域問題,前端配置攔截器無效的解決
這篇文章主要介紹了vuecli3打包后出現(xiàn)跨域問題,前端配置攔截器無效的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
vue在取對(duì)象長(zhǎng)度length時(shí)候出現(xiàn)undefined的解決
這篇文章主要介紹了vue在取對(duì)象長(zhǎng)度length時(shí)候出現(xiàn)undefined的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
詳解vue中v-model和v-bind綁定數(shù)據(jù)的異同
這篇文章主要介紹了vue中v-model和v-bind綁定數(shù)據(jù)的異同,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
淺談vue 組件中的setInterval方法和window的不同
這篇文章主要介紹了淺談vue 組件中的setInterval方法和window的不同,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07

