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>
相关推荐
毕设源码-朱学姐4 小时前
【开题答辩全过程】以 工厂能耗分析平台的设计与实现为例,包含答辩的问题和答案
java·vue.js
老前端的功夫5 小时前
Vue 3 性能深度解析:从架构革新到运行时的全面优化
javascript·vue.js·架构
天天扭码5 小时前
如何实现流式输出?一篇文章手把手教你!
前端·aigc·ai编程
前端 贾公子6 小时前
vue移动端适配方案 === postcss-px-to-viewport
前端·javascript·html
GISer_Jing7 小时前
AI营销增长:4大核心能力+前端落地指南
前端·javascript·人工智能
明远湖之鱼7 小时前
一种基于 Service Worker 的渐进式渲染方案的基本原理
前端
前端小端长8 小时前
Vue 中 keep-alive 组件的原理与实践详解
前端·vue.js·spring
FeelTouch Labs8 小时前
Nginx核心架构设计
运维·前端·nginx
雪球工程师团队8 小时前
别再“苦力”写后台,Spec Coding “跑” 起来
前端·ai编程