vue組件添加事件@click.native操作
1,給vue組件綁定事件時(shí)候,必須加上native ,否則會(huì)認(rèn)為監(jiān)聽的是來自Item組件自定義的事件
2,等同于在子組件中: 子組件內(nèi)部處理click事件然后向外發(fā)送click事件:$emit("click".fn)
<Item @click.native = "shijian()"></Item>
補(bǔ)充知識(shí):vue——組件間(兄弟組件間)事件派發(fā)與接收
法一
main.js
在初始化vue之前,給 data 添加一個(gè)名為 event 的空vue對(duì)象
new Vue({ render: h => h(App), router, store, data: { event: new Vue() } }).$mount('#app')
組件一:
methods: { addCart (e) { let pos = { x: parseInt(e.target.getBoundingClientRect().x + 4), y: parseInt(e.target.getBoundingClientRect().y + 4) } this.$root.event.$emit('ballPosition', pos) } }
組件二:
created () { this.$root.event.$on('ballPosition', (target) => { this._initBall(target) }) }, methods: { _initBall (target) { this.ball = true this.ballMassage = target } }
完整案例:
拋物小球動(dòng)畫:
created () { this.$root.event.$on('ballPosition', (target) => { this._initBall(target) }) }, methods: { _initBall (el) { this.ball.show = true this.ball.el = el }, beforeEnter (el) { let pos = this.ball.el.target.getBoundingClientRect() el.style.top = `${pos.y}px` el.style.left = `${pos.x}px` }, enter (el, done) { // 觸發(fā)動(dòng)畫重繪 el.offsetHeight let [x, y] = [parseInt(this.$refs.cart.getBoundingClientRect().x + 4), parseInt(this.$refs.cart.getBoundingClientRect().y + 8)] el.style.top = `${y}px` el.style.left = `${x}px` el.style.transition = `left .1s linear, top .1s cubic-bezier(.63,.02,.96,.56)` done() }, afterEnter () { this.ball.show = false } },
法二
中央通信: let eventVue = new Vue()
A methods:{function(){eventVue.$emit('自定義事件','數(shù)據(jù)')}}
B created(){eventVue.$on('A 發(fā)送過來的事件名','函數(shù)')}
中央通信:
let eventVue = new Vue()
兄弟組件 A 如下:
<template> <div class="components-a"> <button @click="abtn">A按鈕</button> </div> </template> <script> import eventVue from '../../js/event.js' export default { name: 'app', data () { return { ‘msg':"我是組件A" } }, methods:{ abtn:function(){ eventVue.$emit("myFun",this.msg) //$emit這個(gè)方法會(huì)觸發(fā)一個(gè)事件 } } } </script>
兄弟組件 B 如下:
<template> <div class="components-a"> <div>{{btext}}</div> </div> </template> <script> import eventVue from '../../js/event.js' export default { name: 'app', data () { return { 'btext':"我是B組件內(nèi)容" } }, created:function(){ this.bbtn(); }, methods:{ bbtn:function(){ eventVue.$on("myFun",(message)=>{ //這里最好用箭頭函數(shù),不然this指向有問題 this.btext = message }) } } } </script>
以上這篇vue組件添加事件@click.native操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解使用mpvue開發(fā)github小程序總結(jié)
這篇文章主要介紹了詳解使用mpvue開發(fā)github小程序總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-07-07基于Vue uniapp實(shí)現(xiàn)貪吃蛇游戲
貪吃蛇游戲想必是很多70、80后的回憶,一直到現(xiàn)在也深受大家的喜歡。本文將利用Vue+uniapp實(shí)現(xiàn)這一經(jīng)典的游戲,感興趣的可以了解一下2022-04-04vue-cli中devServer.proxy相關(guān)配置項(xiàng)的使用
這篇文章主要介紹了vue-cli中devServer.proxy相關(guān)配置項(xiàng)的使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04Vue2 Element Schema Form 配置式生成表單的實(shí)現(xiàn)
本文主要介紹了Vue2 Element Schema Form 配置式生成表單的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05Vuejs 組件——props數(shù)據(jù)傳遞的實(shí)例代碼
本篇文章主要介紹了Vuejs 組件——props數(shù)據(jù)傳遞的實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03vue自定義table表如何實(shí)現(xiàn)內(nèi)容上下循環(huán)滾動(dòng)
這篇文章主要介紹了vue自定義table表如何實(shí)現(xiàn)內(nèi)容上下循環(huán)滾動(dòng)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10VUE中如何優(yōu)雅實(shí)現(xiàn)爺孫組件的數(shù)據(jù)通信
所謂祖孫組件,也就是3層嵌套的組件,下面這篇文章主要給大家介紹了關(guān)于VUE中如何優(yōu)雅實(shí)現(xiàn)爺孫組件的數(shù)據(jù)通信的相關(guān)資料,需要的朋友可以參考下2022-04-04