[Vue]组件自定义事件(一)

简介: [Vue]组件自定义事件

前言

系列文章目录:

[Vue]目录

老师的课件笔记,不含视频 https://www.aliyundrive.com/s/B8sDe5u56BU

笔记在线版: https://note.youdao.com/s/5vP46EPC

视频:尚硅谷Vue2.0+Vue3.0全套教程丨vuejs从入门到精通

自定义事件

自定义事件是一种组件间通信的方式,适用于:子组件 ===> 父组件

使用场景:A是父组件,B是子组件,B想给A传数据,那么就要在A中给B绑定自定义事件(事件的回调在A中)。

1. 自定义属性实现子组件向父组件传递数据

App.vue

<template>
  <div class="app">
    <h1>{{msg}}</h1>
    <School :getSchoolName="getSchoolName"></School>
    <Student></Student>
  </div>
</template>
<script>
//导入子组件
import Student from './components/Student'
import School from './components/School'
export default {
  name: 'App',
  components: { School, Student },
  data() {
    return {
      msg: '你好啊!'
    }
  },
  methods: {
    getSchoolName(name) {
      console.log('App收到了学校名:', name)
    }
  }
}
</script>
<style scoped>
.app {
  background-color: gray;
  padding: 5px;
}
</style>

School.vue

<template>
  <div class="school">
    <h2>学校名称:{{name}}</h2>
    <h2>学校地址:{{address}}</h2>
    <button @click="sendSchoolName">把学校名给App</button>
  </div>
</template>
<script>
  export default {
    name:'School',
    props:['getSchoolName'],
    data() {
      return {
        name:'SGG',
        address:'Beijing',
      }
    },
    methods: {
      sendSchoolName(){
        // 调用父组件传递过来的方法
        // 将数据传递给父组件
        this.getSchoolName(this.name)
      }
    },
  }
</script>
<style scoped>
  .school{
    background-color: skyblue;
    padding: 5px;
  }
</style>

Student.vue

<template>
  <div class="student">
    <h2>学生姓名:{{name}}</h2>
    <h2>学生性别:{{sex}}</h2>
  </div>
</template>
<script>
  export default {
    name:'Student',
    data() {
      return {
        name:'张三',
        sex:'男'
      }
    },
  }
</script>
<style scoped>
  .student{
    background-color: pink;
    padding: 5px;
    margin-top: 30px;
  }
</style>

2. 自定义事件实现子组件向父组件传递数据

2.1 进行自定义事件的绑定

为子组件绑定自定义事件,在父组件中:

<子组件名 @自定义事件名="事件的处理函数"></子组件名>

<子组件名 v-on:自定义事件名="事件的处理函数"></子组件名>

App.vue

<template>
  <div class="app">
    <h1>{{msg}}</h1>
    <School :getSchoolName="getSchoolName"></School>
    <!-- 
      1. 为子组件绑定自定义事件 MyEvent
          当自定义事件 MyEvent 被触发时,
          会调用事件的处理函数 getStudentName
    -->
    <Student @MyEvent="getStudentName"></Student>
  </div>
</template>
<script>
//导入子组件
import Student from './components/Student'
import School from './components/School'
export default {
  name: 'App',
  components: { School, Student },
  data() {
    return {
      msg: '你好啊!'
    }
  },
  methods: {
    getSchoolName(name) {
      console.log('App收到了学校名:', name)
    },
    getStudentName(name) {
      console.log('App收到了学生名:', name)
    }
  }
}
</script>
<style scoped>
.app {
  background-color: gray;
  padding: 5px;
}
</style>

2.2 触发自定义事件

进行自定义事件的触发,需要在被绑定自定义事件的子组件中进行触发。给谁绑定,谁触发。

子组件被绑定的自定义事件,自定义事件会挂载在对应子组件实例对象的$emit属性上。

触发自定义事件:

this.$emit('自定义事件名', 向事件处理函数传递的参数)

Student.vue

<template>
  <div class="student">
    <h2>学生姓名:{{name}}</h2>
    <h2>学生性别:{{sex}}</h2>
    <button @click="sendStudentName">把学生姓名给App</button>
  </div>
</template>
<script>
  export default {
    name:'Student',
    data() {
      return {
        name:'张三',
        sex:'男'
      }
    },
    methods: {
      sendStudentName() {
        // 触发自定义事件
        // 将学生姓名传递给自定义事件的处理函数
        this.$emit('MyEvent', this.name)
      }
    },
  }
</script>
<style scoped>
  .student{
    background-color: pink;
    padding: 5px;
    margin-top: 30px;
  }
</style>

2.3 使用 ref 绑定自定义事件

使用 ref 为子组件绑定自定义事件,需要在mounted()中进行,因为此时组件的真实DOM才被渲染到页面上完成。

2.3.1 语法

使用 ref 绑定自定义事件,在父组件中:

<子组件名 @自定义事件名="事件的处理函数"></子组件名>
mounted(){
  // 先通过 $refs 获取对应的子组件
  // 然后使用 $on 为该子组件绑定自定义事件
  this.$refs.子组件名.$on('自定义事件名', 事件的处理函数)
}

2.3.2 自定义事件的绑定

App.vue

<template>
  <div class="app">
    <h1>{{msg}}</h1>
    <School :getSchoolName="getSchoolName"></School>
    <!-- 
      1. 为子组件绑定自定义事件 MyEvent
          当自定义事件 MyEvent 被触发时,
          会调用事件的处理函数 getStudentName
    -->
    <!-- <Student @MyEvent="getStudentName"></Student> -->
    <!-- 
      2. 使用 ref 进行自定义事件的绑定
    -->
    <Student ref="student"></Student>
  </div>
</template>
<script>
//导入子组件
import Student from './components/Student'
import School from './components/School'
export default {
  name: 'App',
  components: { School, Student },
  data() {
    return {
      msg: '你好啊!'
    }
  },
  methods: {
    getSchoolName(name) {
      console.log('App收到了学校名:', name)
    },
    getStudentName(name) {
      console.log('App收到了学生名:', name)
    }
  },
  mounted() {
    // 为子组件 Student 绑定自定义事件
    this.$refs.student.$on('MyEvent', this.getStudentName)
  },
}
</script>
<style scoped>
.app {
  background-color: gray;
  padding: 5px;
}
</style>

2.3.3 使用 ref 绑定自定义事件的好处

使用 ref 绑定自定义事件的好处,能够更好的处理自定义事件的绑定,能对自定义事件的绑定有更加灵活的控制。

使用 v-on 进行自定义事件的绑定,在页面渲染解析完成,vue就会为其绑定自定义指令,而使用 ref 绑定自定义事件,可以对其绑定的时间进行控制,如:延时、等待请求完成等。

App.vue

<template>
  <div class="app">
    <h1>{{msg}}</h1>
    <School :getSchoolName="getSchoolName"></School>
    <!-- 
      1. 为子组件绑定自定义事件 MyEvent
          当自定义事件 MyEvent 被触发时,
          会调用事件的处理函数 getStudentName
    -->
    <!-- <Student @MyEvent="getStudentName"></Student> -->
    <!-- 
      2. 使用 ref 进行自定义事件的绑定
    -->
    <Student ref="student"></Student>
  </div>
</template>
<script>
//导入子组件
import Student from './components/Student'
import School from './components/School'
export default {
  name: 'App',
  components: { School, Student },
  data() {
    return {
      msg: '你好啊!'
    }
  },
  methods: {
    getSchoolName(name) {
      console.log('App收到了学校名:', name)
    },
    getStudentName(name) {
      console.log('App收到了学生名:', name)
    }
  },
  mounted() {
    // 等待三秒,为子组件 Student 绑定自定义事件
    setTimeout(()=>{
      this.$refs.student.$on('MyEvent', this.getStudentName)
    }, 3000)
  },
}
</script>
<style scoped>
.app {
  background-color: gray;
  padding: 5px;
}
</style>

相关文章
|
6天前
|
移动开发 JavaScript API
Vue Router 核心原理
Vue Router 是 Vue.js 的官方路由管理器,用于实现单页面应用(SPA)的路由功能。其核心原理包括路由配置、监听浏览器事件和组件渲染等。通过定义路径与组件的映射关系,Vue Router 将用户访问的路径与对应的组件关联,支持哈希和历史模式监听 URL 变化,确保页面导航时正确渲染组件。
|
10天前
|
监控 JavaScript 前端开发
ry-vue-flowable-xg:震撼来袭!这款基于 Vue 和 Flowable 的企业级工程项目管理项目,你绝不能错过
基于 Vue 和 Flowable 的企业级工程项目管理平台,免费开源且高度定制化。它覆盖投标管理、进度控制、财务核算等全流程需求,提供流程设计、部署、监控和任务管理等功能,适用于企业办公、生产制造、金融服务等多个场景,助力企业提升效率与竞争力。
61 12
|
6天前
|
JavaScript 前端开发 开发者
Vue中的class和style绑定
在 Vue 中,class 和 style 绑定是基于数据驱动视图的强大功能。通过 class 绑定,可以动态更新元素的 class 属性,支持对象和数组语法,适用于普通元素和组件。style 绑定则允许以对象或数组形式动态设置内联样式,Vue 会根据数据变化自动更新 DOM。
|
7天前
|
JavaScript 前端开发 数据安全/隐私保护
Vue Router 简介
Vue Router 是 Vue.js 官方的路由管理库,用于构建单页面应用(SPA)。它将不同页面映射到对应组件,支持嵌套路由、路由参数和导航守卫等功能,简化复杂前端应用的开发。主要特性包括路由映射、嵌套路由、路由参数、导航守卫和路由懒加载,提升性能和开发效率。安装命令:`npm install vue-router`。
|
28天前
|
JavaScript 安全 API
iframe嵌入页面实现免登录思路(以vue为例)
通过上述步骤,可以在Vue.js项目中通过 `iframe`实现不同应用间的免登录功能。利用Token传递和消息传递机制,可以确保安全、高效地在主应用和子应用间共享登录状态。这种方法在实际项目中具有广泛的应用前景,能够显著提升用户体验。
54 8
|
JavaScript
Vue的非父子组件之间传值
全局事件总线 一种组件间通信的方式,适用于任意组件间通信
|
缓存 JavaScript 前端开发
Vue Props、Slot、v-once、非父子组件间的传值....
Vue Props、Slot、v-once、非父子组件间的传值....
102 0
|
JavaScript
Vue中父子组件传值
先在⽗组件中给⼦组件的⾃定义属性绑定⼀个⽗组件的变量
|
JavaScript
vue 组件传值
vue 组件传值
97 0
|
JavaScript
vue父子组件传值
vue父子组件传值

热门文章

最新文章