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>
相关推荐
烂蜻蜓23 分钟前
前端已死?什么是前端
开发语言·前端·javascript·vue.js·uni-app
Rowrey1 小时前
react+typescript,初始化与项目配置
javascript·react.js·typescript
谢尔登1 小时前
Vue 和 React 的异同点
前端·vue.js·react.js
祈澈菇凉6 小时前
Webpack的基本功能有哪些
前端·javascript·vue.js
小纯洁w6 小时前
Webpack 的 require.context 和 Vite 的 import.meta.glob 的详细介绍和使用
前端·webpack·node.js
想睡好6 小时前
css文本属性
前端·css
qianmoQ7 小时前
第三章:组件开发实战 - 第五节 - Tailwind CSS 响应式导航栏实现
前端·css
记得早睡~7 小时前
leetcode150-逆波兰表达式求值
javascript·算法·leetcode
zhoupenghui1687 小时前
golang时间相关函数总结
服务器·前端·golang·time
White graces7 小时前
正则表达式效验邮箱格式, 手机号格式, 密码长度
前端·spring boot·spring·正则表达式·java-ee·maven·intellij-idea