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

vue組件添加事件@click.native操作

 更新時間:2020年10月30日 11:14:02   作者:練洗之命  
這篇文章主要介紹了vue組件添加事件@click.native操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

1,給vue組件綁定事件時候,必須加上native ,否則會認為監(jiān)聽的是來自Item組件自定義的事件

2,等同于在子組件中: 子組件內部處理click事件然后向外發(fā)送click事件:$emit("click".fn)

<Item @click.native = "shijian()"></Item>

補充知識:vue——組件間(兄弟組件間)事件派發(fā)與接收

法一

main.js

在初始化vue之前,給 data 添加一個名為 event 的空vue對象

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
   }
 }

完整案例:

拋物小球動畫:

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ā)動畫重繪
    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('自定義事件','數據')}}

B created(){eventVue.$on('A 發(fā)送過來的事件名','函數')}

中央通信:

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這個方法會觸發(fā)一個事件
      }
   }
}
</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組件內容"
    }
  },
  created:function(){
    this.bbtn();
  },
  methods:{
    bbtn:function(){
      eventVue.$on("myFun",(message)=>{  //這里最好用箭頭函數,不然this指向有問題
         this.btext = message   
      })
    }
  }
}
</script>

以上這篇vue組件添加事件@click.native操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 詳解使用mpvue開發(fā)github小程序總結

    詳解使用mpvue開發(fā)github小程序總結

    這篇文章主要介紹了詳解使用mpvue開發(fā)github小程序總結,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • 基于Vue uniapp實現貪吃蛇游戲

    基于Vue uniapp實現貪吃蛇游戲

    貪吃蛇游戲想必是很多70、80后的回憶,一直到現在也深受大家的喜歡。本文將利用Vue+uniapp實現這一經典的游戲,感興趣的可以了解一下
    2022-04-04
  • Element-UI中el-table如何合并相同單元格

    Element-UI中el-table如何合并相同單元格

    這篇文章主要給大家介紹了關于Element-UI中el-table如何合并相同單元格的相關資料,el-table的組件的可以合并單元格,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-08-08
  • vue-cli中devServer.proxy相關配置項的使用

    vue-cli中devServer.proxy相關配置項的使用

    這篇文章主要介紹了vue-cli中devServer.proxy相關配置項的使用詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue2 Element Schema Form 配置式生成表單的實現

    Vue2 Element Schema Form 配置式生成表單的實現

    本文主要介紹了Vue2 Element Schema Form 配置式生成表單的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • Vuejs 組件——props數據傳遞的實例代碼

    Vuejs 組件——props數據傳遞的實例代碼

    本篇文章主要介紹了Vuejs 組件——props數據傳遞的實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • 如何在vue里面優(yōu)雅的解決跨域(路由沖突問題)

    如何在vue里面優(yōu)雅的解決跨域(路由沖突問題)

    這篇文章主要介紹了如何在vue里面優(yōu)雅的解決跨域(路由沖突問題),小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • vue自定義table表如何實現內容上下循環(huán)滾動

    vue自定義table表如何實現內容上下循環(huán)滾動

    這篇文章主要介紹了vue自定義table表如何實現內容上下循環(huán)滾動問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue中常見的幾種傳參方式小結

    Vue中常見的幾種傳參方式小結

    Vue組件的使用不管是在平常工作還是在面試面試中,都是頻繁出現的,下面這篇文章主要給大家介紹了關于Vue中常見的幾種傳參方式的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • VUE中如何優(yōu)雅實現爺孫組件的數據通信

    VUE中如何優(yōu)雅實現爺孫組件的數據通信

    所謂祖孫組件,也就是3層嵌套的組件,下面這篇文章主要給大家介紹了關于VUE中如何優(yōu)雅實現爺孫組件的數據通信的相關資料,需要的朋友可以參考下
    2022-04-04

最新評論