夜猫子的知识栈 夜猫子的知识栈
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《Web Api》
    • 《ES6教程》
    • 《Vue》
    • 《React》
    • 《TypeScript》
    • 《Git》
    • 《Uniapp》
    • 小程序笔记
    • 《Electron》
    • JS设计模式总结
  • 《前端架构》

    • 《微前端》
    • 《权限控制》
    • monorepo
  • 全栈项目

    • 任务管理日历
    • 无代码平台
    • 图书管理系统
  • HTML
  • CSS
  • Nodejs
  • Midway
  • Nest
  • MySql
  • 其他
  • 技术文档
  • GitHub技巧
  • 博客搭建
  • Ajax
  • Vite
  • Vitest
  • Nuxt
  • UI库文章
  • Docker
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

夜猫子

前端练习生
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《Web Api》
    • 《ES6教程》
    • 《Vue》
    • 《React》
    • 《TypeScript》
    • 《Git》
    • 《Uniapp》
    • 小程序笔记
    • 《Electron》
    • JS设计模式总结
  • 《前端架构》

    • 《微前端》
    • 《权限控制》
    • monorepo
  • 全栈项目

    • 任务管理日历
    • 无代码平台
    • 图书管理系统
  • HTML
  • CSS
  • Nodejs
  • Midway
  • Nest
  • MySql
  • 其他
  • 技术文档
  • GitHub技巧
  • 博客搭建
  • Ajax
  • Vite
  • Vitest
  • Nuxt
  • UI库文章
  • Docker
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 基础

  • 响应式

  • 组件

    • Prop 验证 与 非 Prop 的 Attribute
    • Attrbuite的继承
    • 使用组件的细节点
    • 祖先组件给后代传值
    • 父组件给子组件传值
    • 子组件派发事件和值给父组件
    • 自定义事件
      • 兄弟组件传值
      • 非父子组件传值
      • 父组件调用子组件方法并传入值
      • 插槽slot
      • 异步组件
      • 动态组件与 v-once 指令
      • vue父子组件的生命周期顺序
    • 过渡&动画

    • 可复用性

    • 工具

    • 规模化

    • 路由(核心)

    • 组合式

    • Vuex

    • Pinia

    • 其他

    • Vue3 源码学习记录

    • 《Vue》笔记
    • 组件
    夜猫子
    2020-02-15
    目录

    自定义事件

    # 自定义事件

    API (opens new window)

    # 在组件标签v-on绑定的事件是自定义事件

    就算是原生事件,绑定了 v-on 后也也变成了自定义事件,必须通过 $emit 派发。

    <div id="root">
        <child @click="handleClick"></child> <!--这里click是自定义事件-->
    </div>
    
    <script type="text/javascript">
        Vue.component('child', {
            template: '<button>Child</button>',
        })
    
        var vm = new Vue({
            el: '#root'
            methods: {
                handleClick() {
                    alert('click')
                }
            }
        })
    </script>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18

    上面这种情况,当点击子组件时并不会触发handleClick()事件,因为此时的click并非原生的点击事件,而是一个自定义事件。

    要想触发组件标签中的click事件需要通过子组件$emit来派发

    <div id="root">
        <child @click="handleClick"></child> 
    </div>
    
    <script type="text/javascript">
        app.component('child', {
            template: '<button @click="handleChildClick">Child</button>', // 这里的click是原生事件
            emits: ['click'], // 在组件上定义发出的事件。
            methods: {
                handleChildClick() {
                    this.$emit('click') // 向父组件派发事件
                }
            }
        })
    
        const vm = Vue.createApp({
            methods: {
                handleClick() { // 子组件触发父组件中的自定义事件 click 后,执行 click 所绑定的 handleClick 事件
                    alert('click')
                }
            }
        }).mount('#root')
    </script>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23

    上面代码中,子组件内的click是原生点击事件,通过$emit派发click自定义事件触发父组件的handleClick()

    # 对 emits 进行事件验证

    与 prop 类型验证类似,如果使用对象语法而不是数组语法定义发出的事件,则可以对它进行验证。

    app.component('custom-form', {
      emits: {
        // 没有验证
        click: null,
    
        // 验证 submit 事件
        submit: ({ email, password }) => {
          if (email && password) {
            return true
          } else {
            console.warn('Invalid submit event payload!')
            return false
          }
        }
      },
      methods: {
        submitForm(email, password) {
          this.$emit('submit', { email, password })
        }
      }
    })
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21

    # 使自定义事件变为原生事件

    使用.native修饰符把自定义事件变为原生事件

    <div id="root">
        <child @click.native="handleClick"></child> <!--自定义事件添加了native修饰符变原生事件-->
    </div>
    
    <script type="text/javascript">
        Vue.component('child', {
            template: '<button>Child</button>',
        })
    
        const vm =Vue.createApp({
            methods: {
                handleClick() {
                    alert('click')
                }
            }
        }).mount('#root')
    </script>
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17

    上面代码中,自定义事件click添加了.native修饰符,使其变为原生事件,从而触发handleClick()。

    # 自定义事件名会自动变小写

    当使用camelCase(驼峰)命名的自定义函数

    this.$emit('myEvent')
    
    1

    则监听这个名字的 kebab-case(烤串) 版本是不会有任何效果的:

    <!-- 没有效果 -->
    <my-component v-on:my-event="doSomething"></my-component>
    
    1
    2

    v-on 事件监听器在 DOM 模板中会被自动转换为全小写 (因为 HTML 是大小写不敏感的),所以 v-on:myEvent 将会变成 v-on:myevent——导致 myEvent 不可能被监听到。

    因此,我们推荐你始终使用 kebab-case(烤串) 的事件名。

    编辑 (opens new window)
    #Vue
    上次更新: 2023/7/11 18:57:41
    子组件派发事件和值给父组件
    兄弟组件传值

    ← 子组件派发事件和值给父组件 兄弟组件传值→

    最近更新
    01
    IoC 解决了什么痛点问题?
    03-10
    02
    如何调试 Nest 项目
    03-10
    03
    Provider注入对象
    03-10
    更多文章>
    Copyright © 2019-2025 Study | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式