Vue修饰符总结

在Vue.js中,修饰符是一种特殊的指令后缀,可以用于改变指令的行为或增加额外的功能。

1. prevent:

  • 使用场景:阻止默认事件行为。
  • 示例场景:阻止表单提交的默认行为。
  • 代码示例:
javascript 复制代码
<template>
  <form @submit.prevent="submitForm">
    <input type="text" v-model="name">
    <button type="submit">提交</button>
  </form>
</template>

<script>
export default {
  data() {
    return {
      name: ''
    };
  },
  methods: {
    submitForm() {
      // 阻止表单提交的默认行为
      // 执行自定义表单提交逻辑
      console.log('提交表单:', this.name);
    }
  }
}
</script>

2. stop:

  • 使用场景:阻止事件冒泡。
  • 示例场景:阻止点击事件冒泡到父元素。
  • 代码示例:
javascript 复制代码
<template>
  <div @click="outerClick">
    <!-- 父元素 -->
    <button @click.stop="innerClick">内部按钮</button>
  </div>
</template>

<script>
export default {
  methods: {
    outerClick() {
      console.log('父元素点击事件');
    },
    innerClick() {
      // 阻止点击事件冒泡到父元素
      console.log('内部按钮点击事件');
    }
  }
}
</script>

3. capture:

  • 使用场景:在事件捕获阶段处理事件。
  • 示例场景:在捕获阶段触发事件处理程序。
  • 代码示例:
javascript 复制代码
<template>
  <div @click.capture="captureClick">
    <!-- 元素内容 -->
  </div>
</template>

<script>
export default {
  methods: {
    captureClick() {
      // 在捕获阶段触发事件处理程序
      console.log('捕获阶段点击事件');
    }
  }
}
</script>

4. self:

  • 使用场景:只有在元素自身上触发时调用事件处理程序。
  • 示例场景:只在元素本身点击时触发事件处理程序。
  • 代码示例:
javascript 复制代码
<template>
  <div @click.self="selfClick">
    <!-- 元素内容 -->
  </div>
</template>

<script>
export default {
  methods: {
    selfClick() {
      // 只在元素本身点击时触发事件处理程序
      console.log('元素本身点击事件');
    }
  }
}
</script>

5. once:

  • 使用场景:只触发一次事件处理程序。
  • 示例场景:点击按钮后只执行一次事件处理程序。
  • 代码示例:
javascript 复制代码
<template>
  <button @click.once="handleClick">点击一次</button>
</template>

<script>
export default {
  methods: {
    handleClick() {
      // 只触发一次事件处理程序
      console.log('按钮点击事件');
    }
  }
}
</script>

6. passive:

  • 使用场景:提高滚动的流畅性。
  • 示例场景:在滚动事件上使用.passive修饰符。
  • 代码示例:
javascript 复制代码
<template>
  <div @scroll.passive="handleScroll">滚动内容</div>
</template>

<script>
export default {
  methods: {
    handleScroll() {
      // 在滚动事件上使用`.passive`修饰符
      console.log('滚动事件');
    }
  }
}
</script>

7. native:

  • 使用场景:监听组件根元素的原生事件。
  • 示例场景:监听组件根元素的点击事件。
  • 代码示例:
javascript 复制代码
<template>
  <my-component @click.native="handleClick">
    <!-- 组件内容 -->
  </my-component>
</template>

<script>
export default {
  methods: {
    handleClick() {
      // 在组件的根元素上监听原生的点击事件
      console.log('组件根元素被点击');
    }
  }
}
</script>
相关推荐
qq_1777673721 分钟前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头882124 分钟前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
程序员清洒2 小时前
Flutter for OpenHarmony:Text — 文本显示与样式控制
开发语言·javascript·flutter
雨季6663 小时前
Flutter 三端应用实战:OpenHarmony 简易“动态内边距调节器”交互模式深度解析
javascript·flutter·ui·交互·dart
天人合一peng3 小时前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
会飞的战斗鸡3 小时前
JS中的链表(含leetcode例题)
javascript·leetcode·链表
方也_arkling4 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
qq_177767374 小时前
React Native鸿蒙跨平台剧集管理应用实现,包含主应用组件、剧集列表、分类筛选、搜索排序等功能模块
javascript·react native·react.js·交互·harmonyos
qq_177767374 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体