vue中$once的使用

简介: vue中$once的使用

$once


可以给组件实例绑定一个自定义事件,但该事件只能被触发一次,触发之后随即被移除


$once的简单使用


<template>
  <div>
    <button @click="$emit('onceHander')">按钮</button>
  </div>
</template>
<script>
export default {
  mounted() {
    this.$once('onceHander', () => {
      console.log('该事件只能够被触发一次,触发后立刻被移除11');
    });
  }
}
</script>


理解


有两个参数,第一个参数为字符串类型,


用来指定绑定的事件名称,第二个参数设置事件的回调函数。


$once可以多次为同一个事件绑定多个回调,触发时。


回调函数按照绑定顺序依次执行。


@click="$emit('onceHander')"
this.$once('onceHander',()=>{})


他们配合使用


$once绑定多个回调


<template>
  <div>
    <button @click="$emit('onceHander')">按钮</button>
  </div>
</template>
<script>
export default {
  mounted() {
    this.$once('onceHander', () => {
      console.log('该事件只能够被触发一次,触发后立刻被移除11');
    });
    this.$once('onceHander', () => {
      console.log('该事件只能够被触发一次,触发后立刻被移除22');
    });
    // 由于绑定了多个回调,所以这两行代码都会被执行的哈
  }
}
</script>


once作为修饰符


<template>
  <div>
    <button @click.once="onceHander">按钮</button>
  </div>
</template>
<script>
export default {
  methods:{
    onceHander(){
      //同样也会触发一次哈
      console.log("XXXX")
    }
  },
}
</script>
onceHander 事件只会被触发一次.
相关文章
|
6天前
|
缓存 监控 JavaScript
探讨优化Vue应用性能和加载速度的策略
【5月更文挑战第17天】本文探讨了优化Vue应用性能和加载速度的策略:1) 精简代码和组件拆分以减少冗余;2) 使用计算属性和侦听器、懒加载、预加载和预获取优化路由;3) 数据懒加载和防抖节流处理高频事件;4) 图片压缩和选择合适格式,使用CDN加速资源加载;5) 利用浏览器缓存和组件缓存提高效率;6) 使用Vue Devtools和性能分析工具监控及调试。通过这些方法,可提升用户在复杂应用中的体验。
21 0
|
6天前
|
JavaScript 前端开发
vue(1),小白看完都会了
vue(1),小白看完都会了
|
1天前
|
JavaScript Java 关系型数据库
基于SprinBoot+vue的租房管理系统2
基于SprinBoot+vue的租房管理系统2
9 0
|
2天前
|
自然语言处理 JavaScript 数据可视化
5个值得推荐的Vue后台管理框架
几个优秀好看的 Vue 后台管理框架,每个框架都有自己的特点和优势,开发者可以根据项目需求选择适合的框架。
14 0
|
6天前
|
JavaScript 开发工具 git
Vue 入门系列:.env 环境变量
Vue 入门系列:.env 环境变量
13 1
|
6天前
|
JavaScript 前端开发 定位技术
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
|
6天前
|
JavaScript
Vue中避免滥用this去读取data中数据
Vue中避免滥用this去读取data中数据
|
6天前
|
JavaScript
vue中使用pinia及持久化
vue中使用pinia及持久化
12 0
|
6天前
|
JavaScript 前端开发 UED
Vue class和style绑定:动态美化你的组件
Vue class和style绑定:动态美化你的组件
|
6天前
|
JavaScript 前端开发 API
Vue 监听器:让你的应用实时响应变化
Vue 监听器:让你的应用实时响应变化