做爰高潮a片〈毛片〉,尤物av天堂一区二区在线观看,一本久久A久久精品VR综合,添女人荫蒂全部过程av

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Vue組件通信的幾種實現方法

來源:懂視網 責編:小采 時間:2020-11-27 21:58:03
文檔

Vue組件通信的幾種實現方法

Vue組件通信的幾種實現方法:組件的通信 一般常見的組件之間的通信有以下幾種情況,A和B,B和C,B和D之間都是父子關系,C和D之間是兄弟組件關系。 常用的通信手段有兩種: 1.ref:給元素或組件注冊引用信息 2.children:訪問父級組件和子組件的實例。 這兩種方式都是直接通過實例的
推薦度:
導讀Vue組件通信的幾種實現方法:組件的通信 一般常見的組件之間的通信有以下幾種情況,A和B,B和C,B和D之間都是父子關系,C和D之間是兄弟組件關系。 常用的通信手段有兩種: 1.ref:給元素或組件注冊引用信息 2.children:訪問父級組件和子組件的實例。 這兩種方式都是直接通過實例的

組件的通信

一般常見的組件之間的通信有以下幾種情況,A和B,B和C,B和D之間都是父子關系,C和D之間是兄弟組件關系。

常用的通信手段有兩種:

1.ref:給元素或組件注冊引用信息

2.children:訪問父級組件和子組件的實例。

這兩種方式都是直接通過實例的方式獲取的方式。示例如下:

//comA組件A
export default {
 data () {
 return {
 title: '測試通信'
 }
 },
 methods: {
 sayHello () {
 window.alert('你好');
 }
 }
}

這里引用組件A

<template>
 <comA ref="comA"></comA>
</template>
<script>
 export default {
 mounted () {
 const comA = this.$refs.comA;
 console.log(comA.title); // 測試通信
 comA.sayHello(); // 調用組件comA的方法
 }
 }
</script>

上面的例子我們可以看出我們使用ref來獲取組件的實例上的方法和數據

<div id="count">
 <button @click="showmsg">
 顯示兩個組件的信息
 </button>
 <child1></child1>
 <child2></child2>
 </div>
<template id="child1">
 <div>
 {{ msg }}
 </div>
</template>
<template id="child2">
 <div>
 {{ msg }}
 </div>
</template>
<script>
 Vue.component('child1', {
 template: '#child1',
 data () {
 return {
 msg: '這是子組件1的信息'
 }
 }
 })
 Vue.component('child2', {
 template: '#child2',
 data () {
 return {
 msg: '這是子組件2的信息'
 }
 }
 })
 new Vue({
 el: '#count',
 data: {
 
 },
 methods: {
 showmsg () {
 for(var i = 0; i < this.$children.length; i++) {
 alert(this.$children[i].msg)
 }
 }
 }
 })
</script>

$children 返回所有子組件的實例,是一個數組

<div id="count">
 父組件中的msg: {{ msg }}
 <child1 ref='c1'></child1>
 <child2 ref='c2'></child2>
 </div>
<template id="child1">
 <div>
 {{ msg }}
 <button @click="showpmsg">
 顯示父組件msg
 </button>
 </div>
</template>
<template id="child2">
 <div>
 {{ msg }}
 </div>
</template>
<script>
 Vue.component('child1', {
 template: '#child1',
 data () {
 return {
 msg: '這是子組件1的信息'
 }
 },
 methods: {
 showpmsg () {
 alert(this.$parent.msg)
 }
 }
 })
 Vue.component('child2', {
 template: '#child2',
 data () {
 return {
 msg: '這是子組件2的信息'
 }
 }
 })
 new Vue({
 el: '#count',
 data: {
 msg: 'hello parent'
 }
 })
</script>

這兩種方式是基于組件的上下文環境訪問到父組件或者全部子組件(數組)。這種方式有很大的弊端是,無法跨級或兄弟間進行通信,比如如下的結構

// parent.vue
<component-a></component-a>
<component-b></component-b>
<component-c></component-c>

我們假如想在組件A中獲取其他組件那么我們可能需要使用vuex或者和Bus事件總線的方式進行解決。

事件總線

定義事件總線的方式有以下兩種

// bus.js 事件總線

import Vue from 'vue'
export const $bus = new Vue()

// main.js我們再main入口中定義這個事件總線
Vue.prototype.$bus = new Vue()

發送事件

對下面comA說明,會接收來自父組件的參數number,并顯示出來;有個按鈕,點擊會調用函數handleAddRandom,生成一個隨機數,并調用事件總線的$emit方法,將隨機數給事件總線,由事件總線進行數據傳遞。

<template>
 <div>
 {{number}}
 <button @click="handleAddRandom">隨機增加</button>
 </div>
</template>

<script>
import $bus from ../bus.js
 export default {
 name: "counter",
 props: {
 number: {
 type: Number
 }
 },
 methods: {
 handleAddRandom() {
 const num = Math.floor(Math.random() * 100 + 1);
 console.log("生產的num:" + num);
 this.$bus.$emit('add', num);
 }
 }
 }
</script>

接收事件

<template>
 <div>
 隨機增加:
 <counter :number="number"></counter>
 </div>
</template>

<script>
 import counter from './counter'

 export default {
 name: "index",
 components: {
 counter
 },
 data() {
 return {
 number: 0
 }
 },
 methods: {
 handleAddRandom(num) {
 this.number += num;
 }
 },
 created() {
 //this.$bus.$on需要在created中使用,否則不會生效
 this.$bus.$on('add', this.handleAddRandom);
 },
 beforeDestroy() {
 //需要在beforeDestroy中移除
 this.$bus.$off('add', this.handleAddRandom);
 }
 }
</script>

<style scoped>

</style>

上面是我們通過事件總線的方式進行通信

然后我們來說下另一種可以媲美Vuex的一種方式provide / inject

provide / inject

說起這兩個API可能大家不太明白我們來舉例子說明

// A組件
export default {
 provide: {
 name: 'Aresn'
 }
}

// B組件
export default {
 inject: ['name'],
 mounted () {
 console.log(this.name); // Aresn
 }
}

代碼中我們可以看到我們再組件A中設置了一個provide:{name:"Aresn"},這個方法的作用就是將該變量提供給所有的子組件。我們在B組件中我們使用indect獲取了這個變量,這樣我們就可以使用this.name獲取到這個那么變量。下面我們可以使用一些騷操作大膽的替代Vuex。(這里說明一下官網中不建議我們是使用這兩個API在常規應用程序中,建議使用在高階組件中,建議歸建議用的好就可以啦)

使用provide / inject期待Vuex

<template>
 <div>
 <router-view></router-view>
 </div>
</template>
<script>
 export default {

 }
</script>
Vue cli中搭建出來的項目結構中都會有一個app.vue作為入口組件,我們可以使用這個API在上面大做文章。
<script>
 export default {
 provide () {
 return {
 app: this
 }
 },
 data () {
 return {
 userInfo: null
 }
 },
 methods: {
 getUserInfo () {
 // 這里通過 ajax 獲取用戶信息后,賦值給 this.userInfo,以下為偽代碼
 $.ajax('/user/info', (data) => {
 this.userInfo = data;
 });
 }
 },
 mounted () {
 this.getUserInfo();
 }
 }
</script>

這里我們把根組件實例作為一個參數傳遞給app變量,下面我們就可以通過app[變量||方法]達到vuex的目的

<template>
 <div>
 {{ app.userInfo }}
 </div>
</template>
<script>
 export default {
 inject: ['app'],
 methods: {
 changeUserInfo () {
 // 這里修改完用戶數據后,通知 app.vue 更新,以下為偽代碼
 $.ajax('/user/update', () => {
 // 直接通過 this.app 就可以調用 app.vue 里的方法
 this.app.getUserInfo();
 })
 }
 }
 }
</script>

但是這樣做有一個弊端那就是可能會讓根組件app.vue的代碼變得特別的臃腫,當然也有解決辦法,我們可以使用mixins混合的方式將不同的邏輯分開寫到不同的js里面然后通過 mixins: [mixins_user]的方式在app.vue中引用這個mixin。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Vue組件通信的幾種實現方法

Vue組件通信的幾種實現方法:組件的通信 一般常見的組件之間的通信有以下幾種情況,A和B,B和C,B和D之間都是父子關系,C和D之間是兄弟組件關系。 常用的通信手段有兩種: 1.ref:給元素或組件注冊引用信息 2.children:訪問父級組件和子組件的實例。 這兩種方式都是直接通過實例的
推薦度:
標簽: VUE 的方法 種方法
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 松原市| 五大连池市| 西青区| 莎车县| 凤冈县| 肇源县| 舟山市| 洪泽县| 安图县| 铅山县| 临沂市| 金乡县| 临高县| 保定市| 苗栗县| 顺义区| 隆化县| 中阳县| 元江| 策勒县| 察隅县| 称多县| 碌曲县| 清新县| 西平县| 嘉禾县| 诸暨市| 崇礼县| 古丈县| 安阳市| 东乌珠穆沁旗| 宣城市| 龙胜| 名山县| 获嘉县| 新河县| 灵宝市| 环江| 全南县| 隆林| 天台县|