vue組件添加事件@click.native操作
1,給vue組件綁定事件時(shí)候,必須加上native ,否則會(huì)認(rèn)為監(jiān)聽(tīng)的是來(lái)自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)畫(huà):
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)畫(huà)重繪
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ā)送過(guò)來(lái)的事件名','函數(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指向有問(wèn)題
this.btext = message
})
}
}
}
</script>
以上這篇vue組件添加事件@click.native操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue項(xiàng)目的屏幕自適應(yīng)多個(gè)方案總結(jié)
最近在用VUE寫(xiě)大屏頁(yè)面,遇到屏幕自適應(yīng)問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目的屏幕自適應(yīng)多個(gè)方案的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06
vue實(shí)現(xiàn)Excel文件的上傳與下載功能的兩種方式
這篇文章主要介紹了vue實(shí)現(xiàn)Excel文件的上傳與下載功能,本文通過(guò)兩種方式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06
詳解vue-cli項(xiàng)目中的proxyTable跨域問(wèn)題小結(jié)
這篇文章主要介紹了詳解vue-cli項(xiàng)目中的proxyTable跨域問(wèn)題小結(jié),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
vue深度監(jiān)聽(tīng)(監(jiān)聽(tīng)對(duì)象和數(shù)組的改變)與立即執(zhí)行監(jiān)聽(tīng)實(shí)例
這篇文章主要介紹了vue深度監(jiān)聽(tīng)(監(jiān)聽(tīng)對(duì)象和數(shù)組的改變)與立即執(zhí)行監(jiān)聽(tīng)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09

