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>
相关推荐
Yaml42 分钟前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理
PleaSure乐事3 分钟前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro
哟哟耶耶4 分钟前
js-将JavaScript对象或值转换为JSON字符串 JSON.stringify(this.SelectDataListCourse)
前端·javascript·json
getaxiosluo5 分钟前
react jsx基本语法,脚手架,父子传参,refs等详解
前端·vue.js·react.js·前端框架·hook·jsx
理想不理想v8 分钟前
vue种ref跟reactive的区别?
前端·javascript·vue.js·webpack·前端框架·node.js·ecmascript
知孤云出岫8 分钟前
web 渗透学习指南——初学者防入狱篇
前端·网络安全·渗透·web
贩卖纯净水.14 分钟前
Chrome调试工具(查看CSS属性)
前端·chrome
栈老师不回家1 小时前
Vue 计算属性和监听器
前端·javascript·vue.js
前端啊龙1 小时前
用vue3封装丶高仿element-plus里面的日期联级选择器,日期选择器
前端·javascript·vue.js
一颗松鼠1 小时前
JavaScript 闭包是什么?简单到看完就理解!
开发语言·前端·javascript·ecmascript