vue子組件改變父組件傳遞的prop值通過(guò)sync實(shí)現(xiàn)數(shù)據(jù)雙向綁定(DEMO)
最近開(kāi)始在用elementUI做一個(gè)后臺(tái)管理系統(tǒng)項(xiàng)目,遇到一個(gè)問(wèn)題,需求是這樣,在父組件有一個(gè)按鈕,點(diǎn)擊按鈕會(huì)顯示彈窗(子組件),在子組件中用的是elementUI 的el-diolog彈窗組件,在關(guān)閉彈窗時(shí)(elementUI自帶事件)便會(huì)報(bào)錯(cuò)。話(huà)不多說(shuō)直接上代碼。
DEMO
這是父組件的代碼:
<template>
<div>
<app-refund :dialogVisible="refundVisible"></app-refund>
// 下面是一個(gè)按鈕,點(diǎn)擊此按鈕會(huì)觸發(fā)refundFunc,并顯示彈窗
<el-dropdown-item @click.native="refundFunc">點(diǎn)擊此按鈕顯示彈窗</el-dropdown-item>
</div>
</template>
<script>
import refund from '@/pages/customer/refund'
export default {
components: {
"app-refund":refund
},
data(){
return {
refundVisible:false
}
},
methods: {
refundFunc:function(){
this.refundVisible=true
}
}
}
</script>
以下是子組件的代碼,為了使代碼看起來(lái)更方便簡(jiǎn)潔,已經(jīng)把其他冗余的代碼刪除,只留下能實(shí)現(xiàn)功能的必要代碼
<template>
<div>
<el-dialog
title="退余額"
:visible.sync="dialogVisible"
width="630px">
</el-dialog>
</div>
</template>
<script>
export default {
props:{
dialogVisible: {
type:Boolean,
default: false,
}
},
}
</script>
以上便是父組件控制子組件的顯示,而在子組件關(guān)閉彈窗的例子,這樣肯定是不行的,因?yàn)樵趘ue中props數(shù)據(jù)是單向流,不能在子組件改變父組件傳過(guò)來(lái)的prop值,而解決方式就是用emit來(lái)更新prop值,解決方案如下。
父組件代碼,js部分和上面一模一樣,這里就不重復(fù)寫(xiě)了:
<template>
<div>
<app-refund :dialogVisible.sync="refundVisible"></app-refund>
// 下面是一個(gè)按鈕,點(diǎn)擊此按鈕會(huì)觸發(fā)refundFunc,并顯示彈窗
<el-dropdown-item @click.native="refundFunc">點(diǎn)擊此按鈕顯示彈窗</el-dropdown-item>
</div>
</template>
子組件代碼:
<template>
<div>
<el-dialog
title="退余額"
:visible.sync="dialogVisible"
:before-close="hidePanel"
width="630px">
</el-dialog>
</div>
</template>
<script>
export default {
props:{
dialogVisible: {
type:Boolean,
default: false,
}
},
methods: {
// 利用sync進(jìn)行數(shù)據(jù)雙向綁定,子組件修改dialogVisible的值,并響應(yīng)到父組件
hidePanel() {
this.$emit('update:dialogVisible', false)
}
},
}
</script>
這里用到了elementUI的before-close方法,是彈窗關(guān)閉前的回調(diào),用在這里的意思是在element自帶的關(guān)閉彈窗方法之前調(diào)用hidePanel方法,由我們來(lái)控制彈窗的關(guān)閉,這樣就能在關(guān)閉時(shí)更新dialogVisible的值,解決報(bào)錯(cuò)。
原理
很多時(shí)候我們需要在子組件中修改prop的值,這樣就破壞了vue的單項(xiàng)數(shù)據(jù)流,利用vue2.3的sync可以實(shí)現(xiàn)數(shù)據(jù)的雙向綁定,這是官方解釋 https://cn.vuejs.org/v2/guide... ,使用方式也很簡(jiǎn)單。
總結(jié)
以上所述是小編給大家介紹的vue子組件改變父組件傳遞的prop值通過(guò)sync實(shí)現(xiàn)數(shù)據(jù)雙向綁定,希望對(duì)大家有所幫助!
- Vue.js實(shí)現(xiàn)數(shù)據(jù)雙向綁定的代碼示例
- 使用Vue.js實(shí)現(xiàn)數(shù)據(jù)的雙向綁定
- Vue父子組件數(shù)據(jù)雙向綁定(父?jìng)髯?、子傳父)及ref、$refs、is、:is的使用與區(qū)別
- 淺析Vue3中通過(guò)v-model實(shí)現(xiàn)父子組件的雙向數(shù)據(jù)綁定及利用computed簡(jiǎn)化父子組件雙向綁定
- vue中如何解除數(shù)據(jù)之間的雙向綁定
- vue3中reactive數(shù)據(jù)被重新賦值后無(wú)法雙向綁定的解決
- proxy實(shí)現(xiàn)vue3數(shù)據(jù)雙向綁定原理
- vue自定義組件實(shí)現(xiàn)v-model雙向綁定數(shù)據(jù)的實(shí)例代碼
- vue 數(shù)據(jù)雙向綁定的實(shí)現(xiàn)方法
- Vue項(xiàng)目開(kāi)發(fā)實(shí)現(xiàn)父組件與子組件數(shù)據(jù)間的雙向綁定原理及適用場(chǎng)景
相關(guān)文章
vue3通過(guò)canvas實(shí)現(xiàn)圖片圈選功能
這篇文章將給大家詳細(xì)介紹了vue3如何通過(guò)canvas實(shí)現(xiàn)圖片圈選功能,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴快來(lái)跟隨小編一起學(xué)習(xí)一下吧2023-12-12
Vue3?在<script?setup>里設(shè)置組件name屬性的方法
這篇文章主要介紹了Vue3?在<script?setup>里設(shè)置組件name屬性的方法,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2023-11-11
Vue登錄功能實(shí)現(xiàn)全套詳解(含封裝axios)
登錄功能對(duì)于前端剛?cè)腴T(mén)不久的同學(xué)來(lái)說(shuō)較為困難,下面這篇文章主要給大家介紹了關(guān)于Vue登錄功能實(shí)現(xiàn)(含封裝axios)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12
vue+axios實(shí)現(xiàn)圖片上傳識(shí)別人臉的示例代碼
本文主要介紹了vue+axios實(shí)現(xiàn)圖片上傳識(shí)別人臉,這里采用的是vant的文件上傳組件,通過(guò)上傳圖片后端識(shí)別圖片里的人臉,感興趣的可以了解一下2021-11-11
vue中使用unity3D如何實(shí)現(xiàn)webGL將要呈現(xiàn)的效果
這篇文章主要介紹了vue中使用unity3D如何實(shí)現(xiàn)webGL將要呈現(xiàn)的效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
Vue中使用vee-validate表單驗(yàn)證的方法
vee validate 一個(gè)輕量級(jí)的 vue表單驗(yàn)證插件。接下來(lái)通過(guò)本文給大家分享Vue中使用vee-validate表單驗(yàn)證的方法,需要的朋友參考下吧2018-05-05

