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

Vue 兄弟組件通信的方法(不使用Vuex)

 更新時間:2017年10月26日 14:18:08   作者:Pany丨  
本篇文章主要介紹了Vue 兄弟組件通信的方法(不使用Vuex),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

項目中,我們經(jīng)常會遇到兄弟組件通信的情況。在大型項目中我們可以通過引入vuex輕松管理各組件之間通信問題,但在一些小型的項目中,我們就沒有必要去引入vuex。下面簡單介紹一下使用傳統(tǒng)方法,實現(xiàn)父子組件通信的方法。

簡單實例:我們在a組件中點擊按鈕,將信息傳給b組件,從而使b組件彈出。

主要的思路就是:先子傳父,在父傳子

首先我們在 a.vue 組件中 ,給按鈕botton綁定一個handleClick事件,事件中我們通過 this.$emit() 方法去觸發(fā)一個自定義事件,并傳遞我們的參數(shù)。

示例中我們通過this.$emit() 去觸發(fā)isLogFn 這個方法自定義事件,并將log 參數(shù)傳遞出去

a.vue

<template>
 <div class="adiv">
 <p>a組件</p>
 <button type="button" v-on:click="handleClick">點擊打開組件b彈窗</button>
 </div>
</template>

<script>

export default {
 methods: {
 handleClick () {
  this.$emit('isLogFn','log')
 }
 }
}
</script>

<style>
.adiv{
 width: 400px;
 height: 200px;
 border: 1px solid #000;
 margin: 0 auto;
}
</style>

第二步,我們要在父組件中去監(jiān)聽這個自定義事件,去觸發(fā)對應的方法,并接受a組件傳過來的參數(shù)。此時我們就完成了子組件向父組件傳值的過程。

示例中,<aPage @isLogFn = "lisLogFn"></aPage> 監(jiān)聽isLogFn 去觸發(fā)我們在父組件中定義的方法lisLogFn,并拿到傳過來的 ‘log' 數(shù)據(jù)。完成子父傳值。

到此,整個過程還沒有結(jié)束,只是完成了一半。接下來我們要完成父子組件傳值,將a組件的信息在傳給b組件。

在< bPage > 標簽中綁定islog 屬性,動態(tài)綁定data中的login 字段,在我們通過lisLogFn 方法拿到 ‘data'之后,我們要判斷 data 傳過來的數(shù)據(jù),根據(jù)判斷結(jié)果去改變data()中的數(shù)據(jù),從而將數(shù)據(jù)傳遞給b組件

App.vue

<template>
 <div id="app">
 <aPage @isLogFn = "lisLogFn"></aPage>
 <bPage :isLog = "login"></bPage>
 </div>
</template>

<script>

import aPage from './components/a.vue'
import bPage from './components/b.vue'

export default {
 data () {
 return {
  login: 'false'
 }
 },
 name: 'app',
 components: {
 aPage,
 bPage
 },
 methods: {
 lisLogFn (data) {
  if (data == 'log') {
  this.login = 'true'
  }
 }
 }
}
</script>

<style>
</style>

最后,b組件中需要創(chuàng)建props,定義一個isLog 屬性,這個屬性就是我們傳過來的數(shù)值。然后我們在計算屬性中處理這個數(shù)據(jù),最終供b組件使用。示例中,我們在v-show="isLogin" 中用來控制彈窗是否打開。

切記!不能直接使用這個props,一定要經(jīng)過computed處理,原因我引用vue官方說明

單向數(shù)據(jù)流

b.vue

<template>
 <div class="bdiv" v-show="isLogin">我是組件B彈窗</div>
</template>

<script>
export default {
 props: ['isLog'],
 data () {
 return {

 }
 },
 computed: {
 isLogin () {
  if(this.isLog == 'true'){
  return true
  } else {
  return false
  }
 }
 }
}
</script>

<style>
 .bdiv{
 width: 200px;
 height: 200px;
 border: 1px #000 solid;
 margin: 0 auto;
 }

</style>

總結(jié): 想要實現(xiàn)兄弟組件傳值,一定要首先熟悉子父,父子之間的傳值。

子父:

  1. 子組件中需要以某種方式例如點擊事件的方法來觸發(fā)一個自定義事件
  2. 將需要傳的值作為$emit的第二個參數(shù),該值將作為實參傳給響應自定義事件的方法
  3. 在父組件中注冊子組件并在子組件標簽上綁定對自定義事件的監(jiān)聽

父子:

  1. 子組件在props中創(chuàng)建一個屬性,用以接收父組件傳過來的值
  2. 在子組件標簽中添加子組件props中創(chuàng)建的屬性,把需要傳給子組件的值賦給該屬性

文中示例 github 地址:https://github.com/enjoy-pany/vue-emit

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • elementui 開始結(jié)束時間可以選擇同一天不同時間段的實現(xiàn)代碼

    elementui 開始結(jié)束時間可以選擇同一天不同時間段的實現(xiàn)代碼

    這篇文章主要介紹了elementui 開始結(jié)束時間可以選擇同一天不同時間段的實現(xiàn)代碼,需要先在main.js中導入相應代碼,代碼簡單易懂,需要的朋友可以參考下
    2024-02-02
  • vue3中form對象無法賦值的問題解決

    vue3中form對象無法賦值的問題解決

    這篇文章給大家介紹了vue3中form對象無法賦值的問題解決,有時候?qū)ο蟮闹邓阑钯x不上值,這時候可以看下賦值的對象變量名是否和頁面組件中的ref相同,文中給出了代碼示例供大家參考,需要的朋友可以參考下
    2024-01-01
  • vue計算屬性get和set用法示例

    vue計算屬性get和set用法示例

    這篇文章主要介紹了vue計算屬性get和set用法,結(jié)合實例形式分析了計算屬性的功能及get和set用法的具體使用技巧,需要的朋友可以參考下
    2019-02-02
  • Vue-CLI多頁分目錄打包的步驟記錄

    Vue-CLI多頁分目錄打包的步驟記錄

    這篇文章主要給大家介紹了關(guān)于Vue-CLI多頁分目錄打包的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • vue封裝第三方插件并發(fā)布到npm的方法

    vue封裝第三方插件并發(fā)布到npm的方法

    本篇文章主要介紹了vue封裝第三方插件并發(fā)布到npm的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • vue?組件通信的多種方式

    vue?組件通信的多種方式

    這篇文章主要介紹了vue?組件通信的幾種方式,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • vuex中Getter的用法詳解

    vuex中Getter的用法詳解

    這篇文章主要給大家介紹了關(guān)于Vuex中Getter的基本使用教程,getter相當于Vuex中的計算屬性 對 state 做處理再返回,本文通過示例代碼將Getter介紹的非常詳細,需要的朋友可以參考下
    2021-07-07
  • Vue學習筆記進階篇之vue-cli安裝及介紹

    Vue學習筆記進階篇之vue-cli安裝及介紹

    這篇文章主要介紹了Vue學習筆記進階篇之vue-cli安裝及介紹,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Element-ui Image圖片按需引入大圖預覽

    Element-ui Image圖片按需引入大圖預覽

    這篇文章主要為大家介紹了Element-ui Image圖片按需引入大圖預覽實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • vue操作下拉選擇器獲取選擇的數(shù)據(jù)的id方法

    vue操作下拉選擇器獲取選擇的數(shù)據(jù)的id方法

    今天小編就為大家分享一篇vue操作下拉選擇器獲取選擇的數(shù)據(jù)的id方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08

最新評論