欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue.js 父子組件通訊開發(fā)實例

 更新時間:2016年09月06日 11:44:37   作者:wxc_niuniu  
這篇文章主要介紹了Vue.js 父子組件通訊開發(fā)實例的相關(guān)資料,本文介紹的非常詳細(xì),具有參考借鑒價值,需要的朋友可以參考下

vue.js,是一個構(gòu)建數(shù)據(jù)驅(qū)動的 web 界面的庫。Vue.js 的目標(biāo)是通過盡可能簡單的 API 實現(xiàn)響應(yīng)的數(shù)據(jù)綁定和組合的視圖組件。(這是官方的一個解釋?。?br />

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

小編從業(yè)前端開發(fā)也有了一年多的時間,剛開始的時候,前端開發(fā)展現(xiàn)的技術(shù)太多,小編有心無力,兼顧不過來,經(jīng)過了解之后,還是選擇了學(xué)原生js基礎(chǔ)兼并jquery的學(xué)習(xí)上路。小編使用vue.js,也是因為業(yè)務(wù)的需求,為什么不選擇angularjs,其實就是同時不能拋棄jquery,vue.js和jquery可以完美的兼容,因為這個項目,小編也是苦逼了好長一段時間,不斷的加班和學(xué)習(xí),避免項目的開發(fā)時間增加,廢話不多說,下面開始一些小編的vue的學(xué)習(xí)總結(jié),寫得不好,也不要見怪哈,寫文一直是我的短板。。。。

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

子組件可以通過 this.parent它的父親組件。根實例的可以使用this.root 訪問它。父有一個數(shù)組 this.children,它所有元素;當(dāng)然,在項目中,我們的組件不可以只有一個或者兩個,當(dāng)組件多了的時候,我們是難以記得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() 廣播事件,事件向下傳導(dǎo)給所有的后代。

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

//$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(){ //當(dāng)點擊這個事件的時候,就會觸發(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)聽相應(yīng)響應(yīng)子組件的事件
'add_msg': function(msg){ // add_msg 是用來監(jiān)聽子組件的方法,當(dāng)接受到子組件的通知的時候,就把子組件更新的數(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ù)來進(jìn)行相應(yīng)的操作

//$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">&nbsp;</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ù)需要有默認(rèn)值的話,需在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

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

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

相關(guān)文章

  • vue?element-ui的table列表中展示多張圖片(可放大)效果實例

    vue?element-ui的table列表中展示多張圖片(可放大)效果實例

    這篇文章主要給大家介紹了關(guān)于vue?element-ui的table列表中展示多張圖片(可放大)效果的相關(guān)資料,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • VUE?Element修改el-input和el-select長度的具體步驟

    VUE?Element修改el-input和el-select長度的具體步驟

    這篇文章主要給大家介紹了關(guān)于VUE?Element修改el-input和el-select長度的具體步驟,文中通過代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-12-12
  • Vue3中watchEffect和watch的基礎(chǔ)應(yīng)用詳解

    Vue3中watchEffect和watch的基礎(chǔ)應(yīng)用詳解

    watch是一個偵聽器,默認(rèn)是懶偵聽的,即僅在偵聽源發(fā)生變化時才執(zhí)行回調(diào)函數(shù),watchEffect是會自動收集函數(shù)里面變量的響應(yīng)式依賴,本文主要來講講二者的區(qū)別,感興趣的可以了解一下
    2023-07-07
  • 詳解用vue.js和laravel實現(xiàn)微信授權(quán)登陸

    詳解用vue.js和laravel實現(xiàn)微信授權(quán)登陸

    本篇文章主要介紹了詳解用vue.js和laravel實現(xiàn)微信授權(quán)登陸,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • vue路由--網(wǎng)站導(dǎo)航功能詳解

    vue路由--網(wǎng)站導(dǎo)航功能詳解

    這篇文章主要介紹了vue路由--網(wǎng)站導(dǎo)航功能詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • vue 父組件通過v-model接收子組件的值的代碼

    vue 父組件通過v-model接收子組件的值的代碼

    這篇文章主要介紹了vue 父組件通過v-model接收子組件的值的代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • Vue數(shù)字輸入框組件示例代碼詳解

    Vue數(shù)字輸入框組件示例代碼詳解

    很多朋友經(jīng)常遇到這樣的功能,只允許輸入數(shù)字,允許設(shè)置初始值、最大值、最小值,今天小編給大家分享示例代碼給大家介紹vue數(shù)字輸入框功能,感興趣的朋友一起看看吧
    2020-01-01
  • vue?element?ui表格相同數(shù)據(jù)合并單元格效果實例

    vue?element?ui表格相同數(shù)據(jù)合并單元格效果實例

    工作中遇到需要根據(jù)單元格某個屬性合并,特此記錄下,下面這篇文章主要給大家介紹了關(guān)于vue?element?ui表格相同數(shù)據(jù)合并單元格效果的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • 解決element-ui el-checkbox的一些坑

    解決element-ui el-checkbox的一些坑

    這篇文章主要介紹了解決element-ui el-checkbox的一些坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue3.0 vue.config.js 配置基礎(chǔ)的路徑問題

    vue3.0 vue.config.js 配置基礎(chǔ)的路徑問題

    這篇文章主要介紹了vue3.0 vue.config.js 配置基礎(chǔ)的路徑問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評論