vue子組件改變父組件傳遞的prop值通過sync實現(xiàn)數(shù)據(jù)雙向綁定(DEMO)
最近開始在用elementUI做一個后臺管理系統(tǒng)項目,遇到一個問題,需求是這樣,在父組件有一個按鈕,點擊按鈕會顯示彈窗(子組件),在子組件中用的是elementUI 的el-diolog彈窗組件,在關(guān)閉彈窗時(elementUI自帶事件)便會報錯。話不多說直接上代碼。
DEMO
這是父組件的代碼:
<template>
<div>
<app-refund :dialogVisible="refundVisible"></app-refund>
// 下面是一個按鈕,點擊此按鈕會觸發(fā)refundFunc,并顯示彈窗
<el-dropdown-item @click.native="refundFunc">點擊此按鈕顯示彈窗</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>
以下是子組件的代碼,為了使代碼看起來更方便簡潔,已經(jīng)把其他冗余的代碼刪除,只留下能實現(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)閉彈窗的例子,這樣肯定是不行的,因為在vue中props數(shù)據(jù)是單向流,不能在子組件改變父組件傳過來的prop值,而解決方式就是用emit來更新prop值,解決方案如下。
父組件代碼,js部分和上面一模一樣,這里就不重復(fù)寫了:
<template>
<div>
<app-refund :dialogVisible.sync="refundVisible"></app-refund>
// 下面是一個按鈕,點擊此按鈕會觸發(fā)refundFunc,并顯示彈窗
<el-dropdown-item @click.native="refundFunc">點擊此按鈕顯示彈窗</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進行數(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方法,由我們來控制彈窗的關(guān)閉,這樣就能在關(guān)閉時更新dialogVisible的值,解決報錯。
原理
很多時候我們需要在子組件中修改prop的值,這樣就破壞了vue的單項數(shù)據(jù)流,利用vue2.3的sync可以實現(xiàn)數(shù)據(jù)的雙向綁定,這是官方解釋 https://cn.vuejs.org/v2/guide... ,使用方式也很簡單。
總結(jié)
以上所述是小編給大家介紹的vue子組件改變父組件傳遞的prop值通過sync實現(xiàn)數(shù)據(jù)雙向綁定,希望對大家有所幫助!
- Vue.js實現(xiàn)數(shù)據(jù)雙向綁定的代碼示例
- 使用Vue.js實現(xiàn)數(shù)據(jù)的雙向綁定
- Vue父子組件數(shù)據(jù)雙向綁定(父傳子、子傳父)及ref、$refs、is、:is的使用與區(qū)別
- 淺析Vue3中通過v-model實現(xiàn)父子組件的雙向數(shù)據(jù)綁定及利用computed簡化父子組件雙向綁定
- vue中如何解除數(shù)據(jù)之間的雙向綁定
- vue3中reactive數(shù)據(jù)被重新賦值后無法雙向綁定的解決
- proxy實現(xiàn)vue3數(shù)據(jù)雙向綁定原理
- vue自定義組件實現(xiàn)v-model雙向綁定數(shù)據(jù)的實例代碼
- vue 數(shù)據(jù)雙向綁定的實現(xiàn)方法
- Vue項目開發(fā)實現(xiàn)父組件與子組件數(shù)據(jù)間的雙向綁定原理及適用場景
相關(guān)文章
Vue3?在<script?setup>里設(shè)置組件name屬性的方法
這篇文章主要介紹了Vue3?在<script?setup>里設(shè)置組件name屬性的方法,本文通過示例代碼給大家介紹的非常詳細,需要的朋友參考下吧2023-11-11
vue+axios實現(xiàn)圖片上傳識別人臉的示例代碼
本文主要介紹了vue+axios實現(xiàn)圖片上傳識別人臉,這里采用的是vant的文件上傳組件,通過上傳圖片后端識別圖片里的人臉,感興趣的可以了解一下2021-11-11
vue中使用unity3D如何實現(xiàn)webGL將要呈現(xiàn)的效果
這篇文章主要介紹了vue中使用unity3D如何實現(xiàn)webGL將要呈現(xiàn)的效果,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

