Vue之自定義事件內容分發(fā)詳解
更新時間:2021年11月18日 09:58:42 作者:咸魚_翻身
這篇文章主要為大家介紹了Vue的自定義事件內容分發(fā),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
1、小伙伴們這個理解起來有點復雜,希望仔細看里面的原理,自己去敲一遍:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <div id="app"> <todo> <xian slot="xian" :title="title"></xian> // 建議從后面往前看,理解為遍歷得到的值賦值給v-bind,v-bind的值賦值給props同名的值 // [提醒]v-on:綁定的自定義事件名會自動變成小寫,如果有人事件名用了大寫,下面this.$emit里仍然是大寫,會綁定不上 <yu slot="yu" v-for="(item,index) in items" v-bind:item="item" v-bind:index="index" v-on:remove="deleteItems(index)"></yu> // Vue實例將數(shù)據(jù)和方法與View層綁定,View層在分發(fā)這些數(shù)據(jù)和方法到下面的組件綁定,View相當于中轉了Vue實例的數(shù)據(jù)和方法交由組件控制 </todo> </div> <script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script> <script> Vue.component("todo",{ template: '<div>\ <slot name="xian"></slot>\ <ul>\ <slot name="yu"></slot>\ </ul>\ </div>' }); Vue.component("xian",{ props: ['title'], template: '<div>{{title}}</div>' }); Vue.component("yu",{// props是參數(shù)名,類似于變量名,可以隨便定義,v-bind綁定的是變量,是數(shù)據(jù),是定義的變量 props: ['item','index'], // 只能綁定當前組件的方法 template: '<li>{{index}}---->{{item}}<button @click="remove">delete</button></li>', methods: { remove: function (index) { // this.$emit 自定義事件分發(fā) // 【注意】this.$emit('事件名')這個事件名要使用kebab-case(短橫線命名)方式,不要寫成camelCased (駝峰式); this.$emit('remove',index); } } }); var vm = new Vue({ el: "#app", data: { title: "作者", items: ['咸魚翻身1','咸魚翻身2','咸魚翻身3'] }, methods: { deleteItems: function (index) { console.log("您刪除了"+this.items[index]); this.items.splice(index,1); } } }); </script> </body> </html>
運行結果:
當我們點擊刪除就能刪除任意的作者名字,這里我點擊刪除第二個,顯示結果如下:
2、這里有一個圖供大家理解:
理解大概是這樣 組件和實例之間方法不能互調 而要刪除的節(jié)點屬于實例的屬性 所以通過事件分發(fā)讓組件中定義的方法轉向實例中定義的方法 然后刪除節(jié)點
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
教你如何在 Nuxt 3 中使用 wavesurfer.js
這篇文章主要介紹了如何在 Nuxt 3 中使用 wavesurfer.js,本文結合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-01-01Vue filter 過濾當前時間 實現(xiàn)實時更新效果
這篇文章主要介紹了Vue filter 過濾當前時間 實現(xiàn)實時更新效果,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12Vue手把手教你擼一個 beforeEnter 鉤子函數(shù)
這篇文章主要介紹了Vue手把手教你擼一個 beforeEnter 鉤子函數(shù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04