摘要:自定義事件自定義事件有能力使子組件事件觸發(fā)父組件中的動作。它所做的只是報告自己的內(nèi)部事件,因為父組件可能會關心這些事件。只是這里父組件上的事件功效沒有雙向綁定中事件那么強大。
自定義事件
自定義事件有能力使子組件事件觸發(fā)父組件中的動作。
那么父組件如何監(jiān)聽事件呢?可以使用指令v-on:event-name="callback"監(jiān)聽。
而子組件又是如何觸發(fā)事件的呢? 很簡單,調(diào)用this.$emit(eventName)。
先來個簡單例子
new Vue({ el:"#app-1", methods:{ callback:function(){ alert("父組件監(jiān)聽到事件觸發(fā),執(zhí)行回調(diào)。") } }, components: { "component-1":{ template:"", methods:{ emitor:function(){ console.log("111") this.$emit("alert-event") } } } } })
根據(jù)以上代碼,可以得出個事件執(zhí)行流程,基本上不管什么自定義事件都是這個流程
子組件某方法
this.$emit("event")
DOM上v-on監(jiān)聽event
父組件methods中的callback
子組件已經(jīng)和它外部完全解耦了。它所做的只是報告自己的內(nèi)部事件,因為父組件可能會關心這些事件。事件負載
在事件執(zhí)行的同時,子組件還可以在觸發(fā)事件的同時掛上一些負載的數(shù)據(jù),隨著事件傳遞給父組件。
使用API的第二個參數(shù)this.$emit(event, payload),具體如下。
new Vue({ el: "#app-2", data: { message: "" }, methods: { handleMessage: function (payload) { this.message = payload.message } }, components: { "component-2": { data: function () { return { message: "" } }, template: "", methods: { sendMsg: function () { this.$emit("message", { message: this.message }) } } } } })
點擊發(fā)送按鈕觸發(fā)事件并把信息傳遞給父組件,可以看到還是這里同樣遵循自定義事件流程,其他都是煙霧,之多了個負載this.$emit("message", { message: this.message })
原生事件通過.native后綴還可以在子組件元素根節(jié)點上綁定原生事件的監(jiān)聽。
new Vue({ el:"#app-3", methods:{ todo:function(){ alert("事件回調(diào)方法是父組件中的") } }, components:{ "component-3":{ template:"" } } })
還是要千萬注意,回調(diào)方法在父組件作用域上。
雙向綁定(.sync修飾符與update事件)可以通過以下步驟實現(xiàn)一個雙向綁定:
在子組件VirtualDOM節(jié)點上,通過v-bind:prop.sync="foo"進行數(shù)據(jù)下發(fā),這里以.sync修飾符標注,通知父組件子組件需要進行props的更新。
子組件通過this.$emit("update:prop",newValue)通知父組件自己需要把prop更新為一個新值newValue(以子組件的data選項作為過渡變量)
父組件會監(jiān)聽這個更新事件,從而在負載上拿到newValue,更新foo的數(shù)據(jù),并把新數(shù)據(jù)重新下發(fā)給子組件的prop
注意:這里并不是子組件props值的改變引發(fā)父組件數(shù)據(jù)的改變,而是利用子組件的data做橋梁,通過事件及其負載引起父組件的變動。
new Vue({ el: "#app-4", data: { parentMsg: "parent"s message" }, components: { "component-4": { props: ["child_msg"], data: function () { return { inputText: this.child_msg } }, template: "", watch: { child_msg: function (val) { this.inputText = val }, inputText: function (val) { this.$emit("update:child_msg", val) } } } } })
父、子組件各包含一個輸入框,并且將它們綁定到自己的某data屬性上。watch子組件的該data屬性,一有輸入就觸發(fā)事件通知父組件,并payload新值。父組件通過payload更新自己的data,并通過prop將新值下發(fā)給子組件,子組件watch自己的prop,prop一旦變動,將新變動賦給data。
理解v-model 在input元素上使用我們在用輸入框時,會用v-model進行雙向綁定。
等價于
具體行為:① 在input的value屬性上引用組件的data ② 發(fā)生oninput事件時,更新組件data,從而更新value。
new Vue({ el:"#app-6", data:{ message:"Hello" } })
在自定義事件的表單輸入組件上使用{{message}}
前提:
等價于
new Vue({ el: "#app-7", data: { price: 100 }, components: { "component-7": { props: ["value"], template: "", methods:{ updateValue:function(value){ value = value+"-" this.$emit("input",value) } } } }, }) 子組件Prop:【{{value}}】
父組件數(shù)據(jù):【{{price}}】
這里的流程,輸入框輸入時,觸發(fā)子組件上input事件并執(zhí)行updateValue方法,方法參數(shù)為輸入框中的value(通過$emit.target.value獲?。?,方法可以先對value進行一系列加工處理形成super_value,最后使用this.$emit("input",super_value)觸發(fā)父組件在子組件節(jié)點上監(jiān)聽的input事件,并將加工過的super_value負載在事件上。父組件@input="price = arguments[0]"中的arguments[0]即是這個super_value,父組件通過input的回調(diào)更新自己的data,在將data下發(fā)給子組件的value特性。
這里如果使用v-model指令,那么子組件特性value、父組件監(jiān)聽的事件input及其回調(diào)price = arguments[0], 這些都是固定的,不能變化。
此示例的執(zhí)行流程其實與雙向綁定(.sync修飾符與update事件)中的例子是一樣的。
只是這里父組件上的input事件功效沒有雙向綁定中update事件那么強大。
在輸入框組件中已經(jīng)說過v-model的種種限制,其中最主要的兩點,下發(fā)的組件特性必須命名為value和父組件監(jiān)聽的只能綁定事件input,不靈活, 例如在checkbox中,我要給下發(fā)的特性取名為checked代替value,并且父組件不想監(jiān)聽@input事件,而是@change事件。
為了解決這個不靈活的問題,可以在組件model選項設置prop和event,如下
new Vue({ el: "#app-9", data: { isChecked: false, message:"please choose this box" }, components: { "component-9": { model: { prop: "checked", event: "change" }, props:{ checked:Boolean, value:String }, template: "", methods:{ choose:function(checked){ this.$emit("change",checked) } } } } })
特性`value`現(xiàn)在從v-model綁定中解放出來了,可自定義使用
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/52001.html
摘要:自定義事件自定義事件有能力使子組件事件觸發(fā)父組件中的動作。它所做的只是報告自己的內(nèi)部事件,因為父組件可能會關心這些事件。只是這里父組件上的事件功效沒有雙向綁定中事件那么強大。 自定義事件 自定義事件有能力使子組件事件觸發(fā)父組件中的動作。那么父組件如何監(jiān)聽事件呢?可以使用指令v-on:event-name=callback監(jiān)聽。而子組件又是如何觸發(fā)事件的呢? 很簡單,調(diào)用this.$em...
摘要:寫文章不容易,點個贊唄兄弟專注源碼分享,文章分為白話版和源碼版,白話版助于理解工作原理,源碼版助于了解內(nèi)部詳情,讓我們一起學習吧研究基于版本如果你覺得排版難看,請點擊下面鏈接或者拉到下面關注公眾號也可以吧原理源碼版之綁定組件自定義事件組件 寫文章不容易,點個贊唄兄弟專注 Vue 源碼分享,文章分為白話版和 源碼版,白話版助于理解工作原理,源碼版助于了解內(nèi)部詳情,讓我們一起學習吧研究基于...
摘要:組件化開發(fā)小程序在未出現(xiàn)組件之前,要重用的話,只能簡單復制粗暴黏貼組件化開發(fā)的優(yōu)勢可復用代碼分離,可維護更重要定義組件先創(chuàng)建文件夾用于存放組件,然后再創(chuàng)建組件文件夾注意組件的文件名并不是組件名,而頁面文件名是頁面名,組件名是引用時才確定的引 組件化開發(fā) 小程序在未出現(xiàn)組件之前,要重用的話,只能簡單(復制)粗暴(黏貼) 組件化開發(fā)的優(yōu)勢: 1、可復用(wxml/wxss/js) 2、代...
摘要:自定義組件觸發(fā)的時候。使用外部樣式表在最上方引入文件,微信小程序的路徑一個大坑,接著在引入即可。 好吧,突然發(fā)現(xiàn)學不完了,一下子,那就分開吧,由于時間太久,直接重新大致復習了一下 微信小程序自定義組件微信小程序支持自定義組件下方的目錄showImg(https://melovemingming-1253878077.cos.ap-chengdu.myqcloud.com/blog-im...
摘要:寫文章不容易,點個贊唄兄弟專注源碼分享,文章分為白話版和源碼版,白話版助于理解工作原理,源碼版助于了解內(nèi)部詳情,讓我們一起學習吧研究基于版本如果你覺得排版難看,請點擊下面鏈接或者拉到下面關注公眾號也可以吧原理白話版事件是我最感興趣的東西之 寫文章不容易,點個贊唄兄弟專注 Vue 源碼分享,文章分為白話版和 源碼版,白話版助于理解工作原理,源碼版助于了解內(nèi)部詳情,讓我們一起學習吧研究基于...
閱讀 3273·2021-11-15 11:37
閱讀 1085·2021-11-02 14:45
閱讀 3905·2021-09-04 16:48
閱讀 3582·2019-08-30 15:55
閱讀 757·2019-08-23 17:53
閱讀 1000·2019-08-23 17:03
閱讀 2032·2019-08-23 16:43
閱讀 2191·2019-08-23 16:22