欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue子組件改變父組件傳遞的prop值通過sync實(shí)現(xiàn)數(shù)據(jù)雙向綁定(DEMO)

 更新時(shí)間:2020年02月01日 10:22:34   作者:瑪咖  
本文通過一個(gè)demo給大家介紹了vue子組件改變父組件傳遞的prop值通過sync實(shí)現(xiàn)數(shù)據(jù)雙向綁定,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

最近開始在用elementUI做一個(gè)后臺(tái)管理系統(tǒng)項(xiàng)目,遇到一個(gè)問題,需求是這樣,在父組件有一個(gè)按鈕,點(diǎn)擊按鈕會(huì)顯示彈窗(子組件),在子組件中用的是elementUI 的el-diolog彈窗組件,在關(guān)閉彈窗時(shí)(elementUI自帶事件)便會(huì)報(bào)錯(cuò)。話不多說直接上代碼。

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>

以下是子組件的代碼,為了使代碼看起來更方便簡(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ù)是單向流,不能在子組件改變父組件傳過來的prop值,而解決方式就是用emit來更新prop值,解決方案如下。

父組件代碼,js部分和上面一模一樣,這里就不重復(fù)寫了:

<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方法,由我們來控制彈窗的關(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值通過sync實(shí)現(xiàn)數(shù)據(jù)雙向綁定,希望對(duì)大家有所幫助!

相關(guān)文章

  • vue3通過canvas實(shí)現(xiàn)圖片圈選功能

    vue3通過canvas實(shí)現(xiàn)圖片圈選功能

    這篇文章將給大家詳細(xì)介紹了vue3如何通過canvas實(shí)現(xiàn)圖片圈選功能,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴快來跟隨小編一起學(xué)習(xí)一下吧
    2023-12-12
  • Vue3?在<script?setup>里設(shè)置組件name屬性的方法

    Vue3?在<script?setup>里設(shè)置組件name屬性的方法

    這篇文章主要介紹了Vue3?在<script?setup>里設(shè)置組件name屬性的方法,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2023-11-11
  • Vue登錄功能實(shí)現(xiàn)全套詳解(含封裝axios)

    Vue登錄功能實(shí)現(xiàn)全套詳解(含封裝axios)

    登錄功能對(duì)于前端剛?cè)腴T不久的同學(xué)來說較為困難,下面這篇文章主要給大家介紹了關(guān)于Vue登錄功能實(shí)現(xiàn)(含封裝axios)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • Vue.js實(shí)現(xiàn)列表清單的操作方法

    Vue.js實(shí)現(xiàn)列表清單的操作方法

    Vue.js在設(shè)計(jì)上采用MVVM模式,當(dāng)View視圖層發(fā)生變化時(shí),會(huì)自動(dòng)更新到ViewModel.接下來通過本文給大家分享Vue.js實(shí)現(xiàn)列表清單的操作方法,需要的朋友參考下吧
    2017-11-11
  • vant樣式不生效問題的解決辦法

    vant樣式不生效問題的解決辦法

    這篇文章主要給大家介紹了vant樣式不生效問題的解決辦法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-06-06
  • vue如何自定義配置運(yùn)行run命令

    vue如何自定義配置運(yùn)行run命令

    這篇文章主要介紹了vue如何自定義配置運(yùn)行run命令,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue+axios實(shí)現(xiàn)圖片上傳識(shí)別人臉的示例代碼

    vue+axios實(shí)現(xiàn)圖片上傳識(shí)別人臉的示例代碼

    本文主要介紹了vue+axios實(shí)現(xiàn)圖片上傳識(shí)別人臉,這里采用的是vant的文件上傳組件,通過上傳圖片后端識(shí)別圖片里的人臉,感興趣的可以了解一下
    2021-11-11
  • 源碼分析Vue3響應(yīng)式核心之effect

    源碼分析Vue3響應(yīng)式核心之effect

    這篇文章主要為大家詳細(xì)介紹了Vue3響應(yīng)式核心之effect的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Vue3有一定的幫助,需要的可以參考一下
    2023-04-04
  • vue中使用unity3D如何實(shí)現(xiàn)webGL將要呈現(xiàn)的效果

    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)證的方法

    Vue中使用vee-validate表單驗(yàn)證的方法

    vee validate 一個(gè)輕量級(jí)的 vue表單驗(yàn)證插件。接下來通過本文給大家分享Vue中使用vee-validate表單驗(yàn)證的方法,需要的朋友參考下吧
    2018-05-05

最新評(píng)論