DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Vue.js 父子組件通訊開發實例
Vue.js 父子組件通訊開發實例
編輯:關於JavaScript     

vue.js,是一個構建數據驅動的 web 界面的庫。Vue.js 的目標是通過盡可能簡單的 API 實現響應的數據綁定和組合的視圖組件。(這是官方的一個解釋!)

小編沒使用過angularjs,也沒使用過react.js,不能詳細的說明三者的區別,想了解的話,在官方有一個分析,請點這裡查看

小編從業前端開發也有了一年多的時間,剛開始的時候,前端開發展現的技術太多,小編有心無力,兼顧不過來,經過了解之後,還是選擇了學原生js基礎兼並jquery的學習上路。小編使用vue.js,也是因為業務的需求,為什麼不選擇angularjs,其實就是同時不能拋棄jquery,vue.js和jquery可以完美的兼容,因為這個項目,小編也是苦逼了好長一段時間,不斷的加班和學習,避免項目的開發時間增加,廢話不多說,下面開始一些小編的vue的學習總結,寫得不好,也不要見怪哈,寫文一直是我的短板。。。。

父鏈 小編這裡,就是vue的實例,作為父鏈

子組件可以通過 this.parent它的父親組件。根實例的可以使用this.root 訪問它。父有一個數組 this.children,它所有元素;當然,在項目中,我們的組件不可以只有一個或者兩個,當組件多了的時候,我們是難以記得children中該組件的位置的,我們可以利用 v-ref 的指令,給我們的組件建立一個鉤子,這個鉤子,就是我們的其他組件訪問該組件時的索引

//這是我的一個組件
<msg v-ref:msgs></msg> //這時候,我們就為這個msg組件建立了一個msgs的索引
//我們可以這樣訪問組件
var vm = new Vue({}); 
var children = vm.$refs.msgs //通過這種方式訪問我們的子組件
//v-ref是一個數組或對象,是我們建立所有ref鉤子的組件的集合

這裡,給大家看一張圖,看一下parent,children, $refs相關的內容(好像圖片有點模糊,不會整動態圖,尴尬了,看得不清楚,大家可以自己建立一個demo打印出來好好!)

盡管我們可以這樣直接訪問整個實例裡面的組件,但是不建議如此,因為子組件直接修改父組件的狀態,是非常糟糕的,這會讓父子組件緊密地耦合,理想的情況下,每個組件只能修改自己本身的狀態,因為每個組件的作用域都是獨立的;

這種情況下,vue也為我們帶來了它們的自定義事件

使用 $dispatch() 派發事件,事件沿著父鏈冒泡;

使用 $broadcast() 廣播事件,事件向下傳導給所有的後代。

看起來,有點抽象,來個例子,就好理解很多了

//$dispatch()冒泡案例
<!-- 實例 -->
<div id="app">
<!-- 組件通訊一 -->
<section> 
<div class="mas-arry">
<label for="">msg的數據:</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(){ //當點擊這個事件的時候,就會觸發$dispatch()方法;add_msg是父組件創建的監聽子組件的方法,意思就是,告訴父組件的這個方法,老爸,我更新數據了,par_msg就是我更新的數據,你也快更新吧!把par_msg 的數據傳給父組件更新!
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: { // 創建監聽相應響應子組件的事件
'add_msg': function(msg){ // add_msg 是用來監聽子組件的方法,當接受到子組件的通知的時候,就把子組件更新的數據更新,這裡的msg就是子組件的par_msg
this.msg.push(msg);
}
},
methods: {
add: function(msg){
this.msg.push(msg);
}
}
});
</script>

看完這段代碼,相信大家都知道$dispatch()的冒泡的用法了,其實,就是這麼點東西,裡面有兩個參數,第一個參數,就是父組件監聽子組件events對象裡面的一個方法名,兩者要一致;第二個參數,就是子組件更新的數據,同時也是傳遞給給父組件要同步更新的數據,然後父組件就用這個參數來進行相應的操作

//$broadcast()方法的用法和$dispatch()的用法是一樣的,不一樣的是,event對象是在子組件裡面創建,相反觸發的函數在父組件;這裡要說的是,如果子組件的數據完全依賴於父組件的數據,那麼,則不需要用通說事件傳遞的方式,只需要通過props獲取父組件的數據,綁定到子組件身上就可以了

<!-- 組件通訊二 $broadcast()方法 -->
<section class="sec">
<h3>父組件添加的數據源:</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數據綁定到子組件上 -->
<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是用來接受父組件的傳遞參數,也可在裡面自定義數據,如果數據需要有默認值的話,需在data裡面定義
data: function() {
return {
msg : 'abc' 
}
},
events : { //這裡只是個例子,子組件監聽父組件的數據變化
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>

上處舉的兩個例子,都可以點擊這裡測試,文件已經上傳個人空間 vue父子組件通訊demo

當寫到這裡的時候,回頭看了一下,自己寫的內容,貌似寫得有點亂,真是汗顏啊!很久之前就想過寫博客,建立自己的筆記庫,只是以前嘗試寫的時候,真是無法下手如何去寫,最近,下定決心,不管寫的怎麼樣,也堅持去寫,萬一哪天自己的文筆突然變得好起來了呢!

vue父子組件通訊,其實應用並不是很難,它其實也是提供了相應的api接口監聽,實際的項目應用該如何操作變化,還是得需要我們自己寫,重點,還是得要提高我們的js水平,畢竟,復雜的web應用越來越多!希望,喜歡前端的同學們都能在js的路上共勉.

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved