1. 程式人生 > 實用技巧 >Vue--子元件相互傳參

Vue--子元件相互傳參

引用了element做按鈕元件

父元件

建立子元件公用的空vue變數,為pubVue,並傳給需要互相傳參/互相呼叫方法的兩個子元件

<template>
  <div>
    <btn-tools :pubVue="pubVue" />
    <table-list :pubVue="pubVue" />
  </div>
</template>

<script>
// 元件引用
import TableList from './components/table-list'
import BtnTools from './components/btn-tools'
import Vue from 'vue'

export default {
  name: 'PDmaterialList',
  components: { TableList, BtnTools },
  data() {
    return {
      pubVue: new Vue()
    }
  }
}
</script>

子元件一 $emit傳送事件

<template>
  <div>
    <el-button icon="el-icon-search" type="primary" @click="test" />
  </div>
</template>

<script>
export default {
  props: {
    pubVue: {
      type: Object
    }
  },
  methods: {
    test() {
      console.log('方法派發')
      this.pubVue.$emit('YOUR_EVENT_NAME', {
        name: '張三'
      })
    }
  }
}
</script>

子元件二 $on監聽事件

<template>
  <div>
    <div>子元件二</div>
  </div>
</template>

<script>
export default {
  props: {
    pubVue: {
      type: Object
    }
  },
  mounted() {
    this.pubVue.$on('YOUR_EVENT_NAME', data => {
      console.log('方法監聽', data)
    })
  }
}
</script>

借鑑部落格

vue 事件派發和監聽 (兩種方法)
vue2中$emit $on $off實現元件之間的聯動,絕對有你想了解的

2020年10月28日