Vue.js 父子組件通訊開發(fā)實例
vue.js,是一個構(gòu)建數(shù)據(jù)驅(qū)動的 web 界面的庫。Vue.js 的目標是通過盡可能簡單的 API 實現(xiàn)響應的數(shù)據(jù)綁定和組合的視圖組件。(這是官方的一個解釋?。?br />
小編沒使用過angularjs,也沒使用過react.js,不能詳細的說明三者的區(qū)別,想了解的話,在官方有一個分析,請點這里查看
小編從業(yè)前端開發(fā)也有了一年多的時間,剛開始的時候,前端開發(fā)展現(xiàn)的技術(shù)太多,小編有心無力,兼顧不過來,經(jīng)過了解之后,還是選擇了學原生js基礎(chǔ)兼并jquery的學習上路。小編使用vue.js,也是因為業(yè)務(wù)的需求,為什么不選擇angularjs,其實就是同時不能拋棄jquery,vue.js和jquery可以完美的兼容,因為這個項目,小編也是苦逼了好長一段時間,不斷的加班和學習,避免項目的開發(fā)時間增加,廢話不多說,下面開始一些小編的vue的學習總結(jié),寫得不好,也不要見怪哈,寫文一直是我的短板。。。。
父鏈 小編這里,就是vue的實例,作為父鏈
子組件可以通過 this.parent它的父親組件。根實例的可以使用this.root 訪問它。父有一個數(shù)組 this.children,它所有元素;當然,在項目中,我們的組件不可以只有一個或者兩個,當組件多了的時候,我們是難以記得children中該組件的位置的,我們可以利用 v-ref 的指令,給我們的組件建立一個鉤子,這個鉤子,就是我們的其他組件訪問該組件時的索引
//這是我的一個組件
<msg v-ref:msgs></msg> //這時候,我們就為這個msg組件建立了一個msgs的索引
//我們可以這樣訪問組件
var vm = new Vue({});
var children = vm.$refs.msgs //通過這種方式訪問我們的子組件
//v-ref是一個數(shù)組或?qū)ο?,是我們建立所有ref鉤子的組件的集合
這里,給大家看一張圖,看一下parent,children, $refs相關(guān)的內(nèi)容(好像圖片有點模糊,不會整動態(tài)圖,尷尬了,看得不清楚,大家可以自己建立一個demo打印出來好好!)

盡管我們可以這樣直接訪問整個實例里面的組件,但是不建議如此,因為子組件直接修改父組件的狀態(tài),是非常糟糕的,這會讓父子組件緊密地耦合,理想的情況下,每個組件只能修改自己本身的狀態(tài),因為每個組件的作用域都是獨立的;
這種情況下,vue也為我們帶來了它們的自定義事件
使用 $dispatch() 派發(fā)事件,事件沿著父鏈冒泡;
使用 $broadcast() 廣播事件,事件向下傳導給所有的后代。
看起來,有點抽象,來個例子,就好理解很多了
//$dispatch()冒泡案例
<!-- 實例 -->
<div id="app">
<!-- 組件通訊一 -->
<section>
<div class="mas-arry">
<label for="">msg的數(shù)據(jù):</label>{{ msg }}
</div>
<!--子組件 -->
<msg></msg>
</section>
</div>
<template id="msg">
<div class="inp">
<input type="text" v-model="msg">
<a href="javascript:;" @click="add_data">添加</a>
</div>
</template>
<script>
Vue.component('msg',{ //這里直接使用了注冊組件的語法糖的方式注冊,簡單快捷
template: '#msg',
data: function() {
return {
msg : 'abc'
}
},
methods: {
add_data: function(){ //當點擊這個事件的時候,就會觸發(fā)$dispatch()方法;add_msg是父組件創(chuàng)建的監(jiān)聽子組件的方法,意思就是,告訴父組件的這個方法,老爸,我更新數(shù)據(jù)了,par_msg就是我更新的數(shù)據(jù),你也快更新吧!把par_msg 的數(shù)據(jù)傳給父組件更新!
var par_msg = this.msg.trim();
// this.$parent.add(par_msg); //此方式是直接操作父組件的方法
this.$dispatch('add_msg', par_msg); //此方法是利用事件傳播的方式
this.msg = '';
}
}
});
var mvvm = new Vue({
el: '#app',
data: {
msg : ['sgsg']
},
events: { // 創(chuàng)建監(jiān)聽相應響應子組件的事件
'add_msg': function(msg){ // add_msg 是用來監(jiān)聽子組件的方法,當接受到子組件的通知的時候,就把子組件更新的數(shù)據(jù)更新,這里的msg就是子組件的par_msg
this.msg.push(msg);
}
},
methods: {
add: function(msg){
this.msg.push(msg);
}
}
});
</script>
看完這段代碼,相信大家都知道$dispatch()的冒泡的用法了,其實,就是這么點東西,里面有兩個參數(shù),第一個參數(shù),就是父組件監(jiān)聽子組件events對象里面的一個方法名,兩者要一致;第二個參數(shù),就是子組件更新的數(shù)據(jù),同時也是傳遞給給父組件要同步更新的數(shù)據(jù),然后父組件就用這個參數(shù)來進行相應的操作
//$broadcast()方法的用法和$dispatch()的用法是一樣的,不一樣的是,event對象是在子組件里面創(chuàng)建,相反觸發(fā)的函數(shù)在父組件;這里要說的是,如果子組件的數(shù)據(jù)完全依賴于父組件的數(shù)據(jù),那么,則不需要用通說事件傳遞的方式,只需要通過props獲取父組件的數(shù)據(jù),綁定到子組件身上就可以了
<!-- 組件通訊二 $broadcast()方法 -->
<section class="sec">
<h3>父組件添加的數(shù)據(jù)源:</h3>
<div class="box clearfix">
<label for="" class="box-left">id:</label>
<div class="bor-right">
<input type="text" v-model="id">
</div>
</div>
<div class="box clearfix">
<label for="" class="box-left">姓名:</label>
<div class="bor-right">
<input type="text" v-model="name">
</div>
</div>
<div class="box clearfix">
<label for="" class="box-left">愛好:</label>
<div class="bor-right">
<input type="text" v-model="inst">
</div>
</div>
<div class="box clearfix">
<label for="" class="box-left"> </label>
<div class="bor-right">
<a href="javascrip:;" @click="add_table">添加</a>
</div>
</div>
<h3>下面的表格是子組件信息:</h3>
<!-- 把父組件的table_data數(shù)據(jù)綁定到子組件上 -->
<broadcase :data="table_data"></broadcase>
</section>
<template id="broadcase">
<div class="table">
<table>
<thead>
<tr>
<th>id</th>
<th>姓名</th>
<th>愛好</th>
</tr>
</thead>
<tbody>
<tr v-for="list in data">
<td>{{ list.id }}</td>
<td>{{ list.name }}</td>
<td>{{ list.inst }}</td>
</tr>
</tbody>
</table>
</div>
</template>
<script>
Vue.component('broadcase',{ //這里直接使用了注冊組件的語法糖的方式注冊,簡單快捷
template: '#broadcase',
props: ['data'], // props是用來接受父組件的傳遞參數(shù),也可在里面自定義數(shù)據(jù),如果數(shù)據(jù)需要有默認值的話,需在data里面定義
data: function() {
return {
msg : 'abc'
}
},
events : { //這里只是個例子,子組件監(jiān)聽父組件的數(shù)據(jù)變化
test : function(msg){
console.log(msg);
}
},
methods: {
}
});
var mvvm = new Vue({
el: '#app',
data: {
table_data: [
{
id: 1,
name: 'gjei',
inst: 'gjweir'
},{
id: 2,
name: 'jiuyer',
inst: 'oiuyt'
}
]
},
methods: {
add_table: function(){
var set = {
id: this.id,
name: this.name,
inst : this.inst
};
this.table_data.push(set);
// this.$broadcast('test', set); //這里,只是一個例子語法
this.id = '';
this.name = '';
this.inst = '';
}
}
});
</script>
上處舉的兩個例子,都可以點擊這里測試,文件已經(jīng)上傳個人空間 vue父子組件通訊demo
當寫到這里的時候,回頭看了一下,自己寫的內(nèi)容,貌似寫得有點亂,真是汗顏?。『芫弥熬拖脒^寫博客,建立自己的筆記庫,只是以前嘗試寫的時候,真是無法下手如何去寫,最近,下定決心,不管寫的怎么樣,也堅持去寫,萬一哪天自己的文筆突然變得好起來了呢!
vue父子組件通訊,其實應用并不是很難,它其實也是提供了相應的api接口監(jiān)聽,實際的項目應用該如何操作變化,還是得需要我們自己寫,重點,還是得要提高我們的js水平,畢竟,復雜的web應用越來越多!希望,喜歡前端的同學們都能在js的路上共勉.
相關(guān)文章
vue?element-ui的table列表中展示多張圖片(可放大)效果實例
這篇文章主要給大家介紹了關(guān)于vue?element-ui的table列表中展示多張圖片(可放大)效果的相關(guān)資料,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下2023-08-08
VUE?Element修改el-input和el-select長度的具體步驟
這篇文章主要給大家介紹了關(guān)于VUE?Element修改el-input和el-select長度的具體步驟,文中通過代碼介紹的非常詳細,對大家學習或者工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-12-12
Vue3中watchEffect和watch的基礎(chǔ)應用詳解
watch是一個偵聽器,默認是懶偵聽的,即僅在偵聽源發(fā)生變化時才執(zhí)行回調(diào)函數(shù),watchEffect是會自動收集函數(shù)里面變量的響應式依賴,本文主要來講講二者的區(qū)別,感興趣的可以了解一下2023-07-07
詳解用vue.js和laravel實現(xiàn)微信授權(quán)登陸
本篇文章主要介紹了詳解用vue.js和laravel實現(xiàn)微信授權(quán)登陸,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06
vue?element?ui表格相同數(shù)據(jù)合并單元格效果實例
工作中遇到需要根據(jù)單元格某個屬性合并,特此記錄下,下面這篇文章主要給大家介紹了關(guān)于vue?element?ui表格相同數(shù)據(jù)合并單元格效果的相關(guān)資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2023-11-11
vue3.0 vue.config.js 配置基礎(chǔ)的路徑問題
這篇文章主要介紹了vue3.0 vue.config.js 配置基礎(chǔ)的路徑問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10

