vue3 emits事件使用示例详解

 更新时间:2023年07月03日 11:27:09   作者:CUI_PING  
这篇文章主要为大家介绍了vue3 emits事件使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

使用说明

emits: 列表声明从父组件继承来的事件

$emit: 抛出事件, 通知父组件处理

在子组件中,通过$emit()来触发事件

在父组件中,通过v-on来监听子组件事件

子组件中

export default {
  name: "MyXgPlayer",
  //声明从父组件继承来的事件:可以是简单数组, 也可以是对象(加了校验函数)
  emits: ['just-one-player'],
  props:{
    domId: String,
    previewVideoUrl: String,
  },
  setup(props, context){
    //获取当前实例(包括从父组件传过来的props数据, 实例方法($watch,$emit, $forceUpdate,$nextTick, 定义的全局的$addHost
    // vue 内含的$alert,$message,$messageBox, $store,$router, $refs ...))
    const {proxy} = getCurrentInstance()
    let player = ref(null)
    onMounted(()=>{
        //new 数据
        player.value = new Player ({
        id: props.domId,
        url: props.previewVideoUrl,
      });
      //监听play 事件
      player.value.on('play', ()=>{
        console.log("start $emit")
        //给父组件抛事件
        proxy.$emit("just-one-player", props.domId, player)    
      })
    })
  },
}

父组件中

<my-xg-player 
                :dom-id="'xgplayer_test_'+file.collection_id"
                  :preview-video-url="file.file_path"
                  @justOnePlayer="justOnePlayer"
                  />
<!--script中-->
import {ref} from "vue"
setup(props, context){
   const xgplayers = ref({})
   const justOnePlayer = (domId, player)=>{
          console.log("receive $emit")
          for(let item_key in state.xgplayers){
            if(item_key !== domId){
              state.xgplayers[item_key].pause()
            }
          }
          state.xgplayers[domId] = player
        }
    return {
        xgplayers,
        justOnePlayer
      }
    }
}

点击子组件中的播放,打印的log

start $emit
receive $emit

以上就是vue3 emits事件使用示例详解的详细内容,更多关于vue3 emits事件的资料请关注脚本之家其它相关文章!

相关文章

  • Vue.js 的过滤器你了解多少

    Vue.js 的过滤器你了解多少

    这篇文章主要为大家详细介绍了Vue.js 的过滤器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • 解决vue app.js/vender.js过大优化启动页

    解决vue app.js/vender.js过大优化启动页

    这篇文章主要为大家介绍了解决vue app.js/vender.js过大优化启动页过程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • 详解django模板与vue.js冲突问题

    详解django模板与vue.js冲突问题

    在本文里小编给各位整理了关于django模板与vue.js冲突问题以及实例代码,需要的朋友们参考下。
    2019-07-07
  • vue如何通过src引用assets中的图片

    vue如何通过src引用assets中的图片

    这篇文章主要介绍了vue如何通过src引用assets中的图片,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Vue3和Electron实现桌面端应用详解

    Vue3和Electron实现桌面端应用详解

    本文主要介绍了Vue3和Electron实现桌面端应用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-07-07
  • vue子组件获取到它父组件数据的4种方法

    vue子组件获取到它父组件数据的4种方法

    这篇文章主要给大家介绍了关于vue子组件获取到它父组件数据的4种方法,对于vue来说组件之间的消息传递是非常重要的,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2023-08-08
  • vue filters和directives访问this的问题详解

    vue filters和directives访问this的问题详解

    这篇文章主要介绍了vue filters和directives访问this的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • vue如何将base64流数据转成pdf文件并在新页面打开

    vue如何将base64流数据转成pdf文件并在新页面打开

    这篇文章主要介绍了vue如何将base64流数据转成pdf文件并在新页面打开问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • Vue实现Google第三方登录的示例代码

    Vue实现Google第三方登录的示例代码

    本文记录作者在vue项目中使用到Google第三方登录,查询到的资料文档也不详细,故此把自己所遇到的坑及问题详细的记录下来。
    2021-07-07
  • Vue.js 事件修饰符的使用教程

    Vue.js 事件修饰符的使用教程

    在实际开发中,不可避免的会使用到对于事件的操作,如何处理 DOM 事件流,成为我们必须要掌握的技能。这篇文章主要介绍了Vue.js 事件修饰符的使用教程,需要的朋友可以参考下
    2018-11-11

最新评论