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

盡管我們可以這樣直接訪(fǎng)問(wèn)整個(gè)實(shí)例里面的組件,但是不建議如此,因?yàn)樽咏M件直接修改父組件的狀態(tài),是非常糟糕的,這會(huì)讓父子組件緊密地耦合,理想的情況下,每個(gè)組件只能修改自己本身的狀態(tài),因?yàn)槊總€(gè)組件的作用域都是獨(dú)立的;
這種情況下,vue也為我們帶來(lái)了它們的自定義事件
使用 $dispatch() 派發(fā)事件,事件沿著父鏈冒泡;
使用 $broadcast() 廣播事件,事件向下傳導(dǎo)給所有的后代。
看起來(lái),有點(diǎn)抽象,來(lái)個(gè)例子,就好理解很多了
//$dispatch()冒泡案例
<!-- 實(shí)例 -->
<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',{ //這里直接使用了注冊(cè)組件的語(yǔ)法糖的方式注冊(cè),簡(jiǎn)單快捷
template: '#msg',
data: function() {
return {
msg : 'abc'
}
},
methods: {
add_data: function(){ //當(dāng)點(diǎn)擊這個(gè)事件的時(shí)候,就會(huì)觸發(fā)$dispatch()方法;add_msg是父組件創(chuàng)建的監(jiān)聽(tīng)子組件的方法,意思就是,告訴父組件的這個(gè)方法,老爸,我更新數(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)聽(tīng)相應(yīng)響應(yīng)子組件的事件
'add_msg': function(msg){ // add_msg 是用來(lái)監(jiān)聽(tīng)子組件的方法,當(dāng)接受到子組件的通知的時(shí)候,就把子組件更新的數(shù)據(jù)更新,這里的msg就是子組件的par_msg
this.msg.push(msg);
}
},
methods: {
add: function(msg){
this.msg.push(msg);
}
}
});
</script>
看完這段代碼,相信大家都知道$dispatch()的冒泡的用法了,其實(shí),就是這么點(diǎn)東西,里面有兩個(gè)參數(shù),第一個(gè)參數(shù),就是父組件監(jiān)聽(tīng)子組件events對(duì)象里面的一個(gè)方法名,兩者要一致;第二個(gè)參數(shù),就是子組件更新的數(shù)據(jù),同時(shí)也是傳遞給給父組件要同步更新的數(shù)據(jù),然后父組件就用這個(gè)參數(shù)來(lái)進(jìn)行相應(yīng)的操作
//$broadcast()方法的用法和$dispatch()的用法是一樣的,不一樣的是,event對(duì)象是在子組件里面創(chuàng)建,相反觸發(fā)的函數(shù)在父組件;這里要說(shuō)的是,如果子組件的數(shù)據(jù)完全依賴(lài)于父組件的數(shù)據(jù),那么,則不需要用通說(shuō)事件傳遞的方式,只需要通過(guò)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">愛(ài)好:</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>愛(ài)好</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',{ //這里直接使用了注冊(cè)組件的語(yǔ)法糖的方式注冊(cè),簡(jiǎn)單快捷
template: '#broadcase',
props: ['data'], // props是用來(lái)接受父組件的傳遞參數(shù),也可在里面自定義數(shù)據(jù),如果數(shù)據(jù)需要有默認(rèn)值的話(huà),需在data里面定義
data: function() {
return {
msg : 'abc'
}
},
events : { //這里只是個(gè)例子,子組件監(jiān)聽(tīng)父組件的數(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); //這里,只是一個(gè)例子語(yǔ)法
this.id = '';
this.name = '';
this.inst = '';
}
}
});
</script>
上處舉的兩個(gè)例子,都可以點(diǎn)擊這里測(cè)試,文件已經(jīng)上傳個(gè)人空間 vue父子組件通訊demo
當(dāng)寫(xiě)到這里的時(shí)候,回頭看了一下,自己寫(xiě)的內(nèi)容,貌似寫(xiě)得有點(diǎn)亂,真是汗顏??!很久之前就想過(guò)寫(xiě)博客,建立自己的筆記庫(kù),只是以前嘗試寫(xiě)的時(shí)候,真是無(wú)法下手如何去寫(xiě),最近,下定決心,不管寫(xiě)的怎么樣,也堅(jiān)持去寫(xiě),萬(wàn)一哪天自己的文筆突然變得好起來(lái)了呢!
vue父子組件通訊,其實(shí)應(yīng)用并不是很難,它其實(shí)也是提供了相應(yīng)的api接口監(jiān)聽(tīng),實(shí)際的項(xiàng)目應(yīng)用該如何操作變化,還是得需要我們自己寫(xiě),重點(diǎn),還是得要提高我們的js水平,畢竟,復(fù)雜的web應(yīng)用越來(lái)越多!希望,喜歡前端的同學(xué)們都能在js的路上共勉.
相關(guān)文章
Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問(wèn)題及解決
這篇文章主要介紹了Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-09-09
vue2.0實(shí)現(xiàn)倒計(jì)時(shí)的插件(時(shí)間戳 刷新 跳轉(zhuǎn) 都不影響)
我發(fā)現(xiàn)好多倒計(jì)時(shí)的插件,刷新都會(huì)變成從頭再來(lái),于是自己用vue2.0寫(xiě)了一個(gè),感覺(jué)還不錯(cuò),特此分享到腳本之家平臺(tái)供大家參考下2017-03-03
vue?當(dāng)中組件之間共享數(shù)據(jù)的實(shí)現(xiàn)方式
這篇文章主要介紹了vue?當(dāng)中組件之間共享數(shù)據(jù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
element-ui el-dialog嵌套table組件,ref問(wèn)題及解決
這篇文章主要介紹了element-ui el-dialog嵌套table組件,ref問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02

