亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

vue祖孫組件之間的數據傳遞案例

瀏覽:23日期:2022-10-20 13:47:55

**解決的問題:**

使用$attrs和$listeners實現祖孫組件之間的數據傳遞,也就是多重嵌套組件之間的數據傳遞。

**注意:**

本方法針對vue2.4版本及以上,使用$attrs和$listeners來實現的

**解決方案:**

**首先創建父組件:** 父組件用于動態數據的綁定與事件的定義

<template> <div> <!--這里 :one和:two是向后代組件傳遞數據--> <child1 :one='child1' :two='child2' @test1='onTest1' @test2='onTest2'></child1> </div></template>

<script> import Child1 from ’./Child.vue’; export default { data () { return { child1:’lihua’, child2:’lignag’, parent: 0 }; }, components: { ’child1’:Child1 //引入子組件 }, methods: { onTest1 () { console.log(’child’) }, onTest2 (val) { this.parent = val } } } </script>

子組件的寫法: 通過設置v-bind='$attrs' 和v-on='$listeners'來充當中間人,

<template> <div class='child-1'> <p>$attrs:{{$attrs[’two’]}}</p> <hr> <!-- 子組件中通過v-bind=’$attrs’接受數據,通過$listeners接收事件 --> <child2 v-bind='$attrs' v-on='$listeners'></child2> </div></template>

<script>import child2 from ’./Child2.vue’;export default { props: [’one’,’two’], //可寫可不寫 data () { return { } }, inheritAttrs: false, //父組件傳遞動態數據后,子組件的默認行為 components: { child2 }, mounted () { this.$emit(’test1’) //觸發父組件方法的一種方式 this.$listeners.test2(123) //觸發父組件方法的另一種方式 }}</script>

孫組件寫法: 通過props或者$attrs和$listeners來獲取父組件數據和事件。

<template> <div class='child-2'> <p>props:{{one}}</p> <p>props:{{two}}</p> <p>$attrs: {{$attrs[’one’]}}</p> <hr> </div></template>

<script>export default { props:[’one’,’two’], //接收父組件傳遞的數據,可以不寫,通過$attrs來獲取 data(){ return {}; }, inheritAttrs: false, //默認行為需要取消 mounted(){ this.$emit(’test1’) //觸發父組件方法的一種方式 this.$listeners.test1(123)//觸發父組件方法的另一種方式 }}</script>

另:inheritAttrs的作用:

先注意一點:使用$attrs時inhertAttrs設置為false.

當inheritAttrs設置為true時,父元素動態綁定組件的數據,子組件如果沒有通過props接收的話,該屬性就會附加于子組件的根元素上。什么意思看代碼

//父組件 <child :one='help'></child> data(){ return { help:123 } } //子組件 <template> <div> <h1>作為子組件的我并沒有設置props來接收父組件的one屬性。</h1> </div></template> //父組件解析出來就是這樣 <div one='123'> <h1>作為子組件的我并沒有設置props來接收父組件的one屬性。</h1></div>

所以呢我們通過v-bind='$attrs'來指定父組件數據的綁定位置,同時設置inheritAttrs為false來取消默認行為

補充知識:理解Vue.mixin,利用Vue.mixin正確的偷懶

關于Vue.mixin在vue官方文檔中是這么解釋的:

混入 (mixin) 提供了一種非常靈活的方式,來分發 Vue 組件中的可復用功能。一個混入對象可以包含任意組件選項。當組件使用混入對象時,所有混入對象的選項將被“混合”進入該組件本身的選項。

我們的理解:

Vue.mixin給我們提供了一種混入Vue實例的方法,創建了混入對象之后,我們自定義的方法或者變量可以很輕松的掛載在Vue實例上,給我們的偷懶帶來方便;

Vue.mixin為我們提供了兩種混入方式:局部混入和全局混入;

本文還是以demo形式來進行學習講解,如果有條件最好還是跟著demo敲一遍,這樣印象才會深刻;

局部混入:

顧名思義就是部分混入,也就是只有引入了mixin的混入對象才可以使用,并且只有在引入了mixin混入對象的組件中才生效;

來,知道了概念,我們一起來看看代碼:

首先自己搭建Vue的開發環境,然后我們在src目錄中新建兩個vue文件,分別是page1.vue和page2.vue;

page1.vue

<template> <div>page1的值是:</div></template><script>export default { data () { return { } },}</script><style scoped></style>

page2.vue

<template> <div>page2的值是:</div></template><script>export default { data () { return { } }}</script><style scoped></style>

然后我們修改App.vue

<template> <div id='app'> <button @click='method1'>page1</button> <button @click='method2'>page2</button> <router-view></router-view> </div></template><script>export default { name: ’App’, methods:{ method1(){ this.$router.push(’/page1’); }, method2(){ this.$router.push(’/page2’); } }}</script><style>#app { font-family: ’Avenir’, Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px;}</style>

在src目錄下創建router.js文件,配置路由實現跳轉

import Vue from 'vue';import VueRouter from 'vue-router';Vue.use(VueRouter);import page1 from './page1';import page2 from './page2';const routes=[ {path:'/page1',component:page1}, {path:'/page2',component:page2}]const router=new VueRouter({ routes})export default router

最后將路由引入main.js中:

// The Vue build version to load with the `import` command// (runtime-only or standalone) has been set in webpack.base.conf with an alias.import Vue from ’vue’import App from ’./App’import router from ’./router.js’Vue.config.productionTip = false/* eslint-disable no-new */new Vue({ el: ’#app’, router, components: { App }, template: ’<App/>’})

完成上述準備工作之后,我們可以看到現在的頁面效果如下:

vue祖孫組件之間的數據傳遞案例

沒有報錯,我們開始正式進入學習Vue.mixin:

首先我們在src目錄下新建一個名為mixin的文件夾并在mixin文件中創建一個mixin.js文件:

//拋出混入對象,方便外部訪問export const mixin={ data(){ return { number:1 } }}

可以看到我們在混入對象中創建了一個變量,是的,混入對象跟Vue實例的格式是一樣的;

然后我們可以將mixin.js引入到我們的page1.vue和page2.vue中

page1.vue

<template> //這里讀的值其實是mixin的值,因為這個時候mixin已經混入到vue實例中了 <div>page1的值是:{{number}}</div></template><script>//引入mixin.jsimport {mixin} from './mixin/mixin'export default {//這里注意:屬性名為mixins,值為數組類型 mixins:[mixin], data () { return { } },}</script><style scoped></style>

page2.vue

<template> <div>page2的值是:{{number}}</div></template><script>import {mixin} from './mixin/mixin'export default { mixins:[mixin], data () { return { } }}</script><style scoped></style>

這個時候我們的混入對象已經成功混入到Vue實例中,你們可以點擊看看效果,是可以正常運行并且能讀取到值的;

現在我們來修改page1.vue的代碼: 

<template> <div>page2的值是:{{number}}</div></template><script>import {mixin} from './mixin/mixin'export default { mixins:[mixin], data () { return { } }}</script><style scoped></style>

page2不變,再運行可以發現,我們的page1.vue中的值是執行了mounted,所以產生了自增

由此,我們可以知道mixin混入對象的變量是不會共享的;也就是你page1發生了變化,并不會通知mixin進行實時刷新數據,發生的變化只會在page1.vue中生效,不影響其他組件;

現在我們修改mixin.js和page1.vue中的代碼:

mixin.js

export const mixin={ data(){ return { number:1 } }, created(){ console.log('mixin混入對象') }}

page1.vue

<template> <div>page1的值是:{{number}}</div></template><script>import {mixin} from './mixin/mixin'export default { mixins:[mixin], data () { return { } }, created(){ console.log('這里是page1'); }}</script><style scoped></style>

這個時候我們再運行可以發現控制臺輸出是這個樣子的:

vue祖孫組件之間的數據傳遞案例

是的,mixin混入對象中聲明了:如果是同名鉤子函數將合并為一個數組,因此都被調用,但是混入對象的鉤子將在自身實例鉤子之前觸發;

值為對象的選項,例如methods,components等如果變量名和mixin混入對象的變量名發生沖突,將會以組件優先并進行遞歸合并,相當于組件數據直接覆蓋了mixin中的同名數據;

我們可以修改代碼mixin.js和page1.vue

mixin.js

export const mixin={ data(){ return { number:1 } }, methods:{ demo1(){ console.log('mixin混入對象') } }}

page1.vue

<template> <div>page1的值是:{{number}}</div></template><script>import {mixin} from './mixin/mixin'export default { mixins:[mixin], data () { return { number:10 } }, mounted(){ this.demo1(); }, methods:{ demo1(){ console.log('這里是page1'); } }}</script><style scoped></style>

運行代碼我們可以很清晰的看到都是執行我們組件內的值;

vue祖孫組件之間的數據傳遞案例

因為在vue中我們在實例中聲明變量也是通過鍵值對的形式來聲明的,其實也是一個對象;

全局混入:

全局混入我們只需要把mixin.js引入到main.js中,然后將mixin放入到Vue.mixin()方法中即可;

// The Vue build version to load with the `import` command// (runtime-only or standalone) has been set in webpack.base.conf with an alias.import Vue from ’vue’import App from ’./App’import router from ’./router.js’import mixin from './mixin/mixin.js'Vue.config.productionTip = falseVue.mixin(mixin)/* eslint-disable no-new */new Vue({ el: ’#app’, router, components: { App }, template: ’<App/>’})

是的,全局混入更為便捷,我們將不用在子組件聲明,全局混入將會影響每一個組件的實例,使用的時候需要小心謹慎;這樣全局混入之后,我們可以直接在組件中通過this.變量/方法來調用mixin混入對象的變量/方法;

很多同學可能看到這里會有一些疑問,這不就跟Vuex差不多嘛,其實不是的:

mixin混入對象和Vuex的區別:

Vuex是狀態共享管理,所以Vuex中的所有變量和方法都是可以讀取和更改并相互影響的;

mixin可以定義公用的變量或方法,但是mixin中的數據是不共享的,也就是每個組件中的mixin實例都是不一樣的,都是單獨存在的個體,不存在相互影響的;

mixin混入對象值為函數的同名函數選項將會進行遞歸合并為數組,兩個函數都會執行,只不過先執行mixin中的同名函數;

mixin混入對象值為對象的同名對象將會進行替換,都優先執行組件內的同名對象,也就是組件內的同名對象將mixin混入對象的同名對象進行覆蓋;

以上這篇vue祖孫組件之間的數據傳遞案例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 毛片国产 | 午夜影视水蜜桃网站 | 色婷婷中文字幕在线一区天堂 | 国产成人精选免费视频 | 国产3页| 午夜宅男宅女看在线观看 | 精品国产日韩久久亚洲 | 日韩精品福利视频一区二区三区 | 在线观看精品国语偷拍 | 黄工厂精品视频在线观看 | 亚洲成a人片在线播放观看国产 | 青青草视频在线观看免费 | 国产高清在线看免费视频观 | 一级片黑人 | 国产高清第一页 | 男女晚上激烈的拍拍拍免费看 | 国产午夜成人无码免费看 | 黄色网络在线观看 | 青青青国产在线观看免费 | 国产精品免费观看视频 | 亚洲欧美一区二区三区蜜芽 | 制服丝袜中文字幕第一页 | 亚洲国产一区二区在线 | 国产区综合另类亚洲欧美 | 毛片免费观看网址 | 亚洲 欧美 国产另类首页 | 成人免费视频网站 | 永久视频在线观看 | 伊人一区| 久久草国产 | 日韩欧美视频免费观看 | 天天噜噜揉揉狠狠夜夜 | 久久久91精品国产一区二区 | 国产精品亚洲精品日韩己满十八小 | 亚洲大尺度在线观看 | 亚洲第一国产 | 久久欧美精品欧美九久欧美 | 日韩精品一区二区三区 在线观看 | 成人精品一级毛片 | 免费一级欧美片片线观看 | 激情毛片|