学习Vue时候随手写的东西-2

本文最后更新于:2023年6月25日 晚上

事件绑定

事件修饰符

为了使用方便,Vue 为v-on提供了事件修饰符。修饰符是用.表示的指令后缀,包含以下这些:

  • .stop // event.stopPropagation()
  • .prevent // event.preventDefault()
  • .self
  • .capture
  • .once
  • .passive
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    <!-- 单击事件将停止传递 -->
    <a @click.stop="doThis"></a>

    <!-- 提交事件将不再重新加载页面 -->
    <form @submit.prevent="onSubmit"></form>

    <!-- 修饰语可以使用链式书写 -->
    <a @click.stop.prevent="doThat"></a>

    <!-- 也可以只有修饰符 -->
    <form @submit.prevent></form>

    <!-- 仅当 event.target 是元素本身时才会触发事件处理器 -->
    <!-- 例如:事件处理器不来自子元素 -->
    <div @click.self="doThat">...</div>

    使用修饰符时需要注意调用顺序,因为相关代码是以相同的顺序生成的。
    因此使用@click.prevent.self会阻止元素及其子元素的所有点击事件的默认行为而@click.self.prevent则只会阻止对元素本身的点击事件的默认行为。

    .capture.once.passive修饰符与原生addEventListener事件相对应:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <!-- 添加事件监听器时,使用 `capture` 捕获模式 -->
    <!-- 例如:指向内部元素的事件,在被内部元素处理前,先被外部处理 -->
    <div @click.capture="doThis">...</div>

    <!-- 点击事件最多被触发一次 -->
    <a @click.once="doThis"></a>

    <!-- 滚动事件的默认行为 (scrolling) 将立即发生而非等待 `onScroll` 完成 -->
    <!-- 以防其中包含 `event.preventDefault()` -->
    <div @scroll.passive="onScroll">...</div>
    .passive修饰符一般用于触摸事件的监听器,可以用来改善移动端设备的滚屏性能。

    请勿同时使用.passive.prevent,因为.passive已经向浏览器表明了你不想阻止事件的默认行为。
    如果你这么做了,则.prevent会被忽略,并且浏览器会抛出警告。

按键修饰符

在监听键盘事件时,我们经常需要检查特定的按键。Vue允许在v-on@监听按键事件时添加按键修饰符。

1
2
3
<!-- 仅在 `key` 为 `Enter` 时调用 `submit` -->
<input @keyup.enter="submit" />
<input @keyup.page-down="onPageDown" />

Vue 为一些常用的按键提供了别名:

  • .enter
  • .tab
  • .delete (捕获“Delete”和“Backspace”两个按键)
  • .esc
  • .space
  • .up
  • .down
  • .left
  • .right
    你可以使用以下系统按键修饰符来触发鼠标或键盘事件监听器,只有当按键被按下时才会触发。
  • .ctrl
  • .alt
  • .shift
  • .meta

    请注意,系统按键修饰符和常规按键不同。与keyup事件一起使用时,该按键必须在事件发出时处于按下状态。
    换句话说,keyup.ctrl只会在你仍然按住ctrl但松开了另一个键时被触发。若你单独松开ctrl键将不会触发。

    .exact修饰符允许控制触发一个事件所需的确定组合的系统按键修饰符。
    1
    2
    3
    4
    5
    6
    7
    8
    <!-- 当按下 Ctrl 时,即使同时按下 Alt 或 Shift 也会触发 -->
    <button @click.ctrl="onClick">A</button>

    <!-- 仅当按下 Ctrl 且未按任何其他键时才会触发 -->
    <button @click.ctrl.exact="onCtrlClick">A</button>

    <!-- 仅当没有按下任何系统按键时触发 -->
    <button @click.exact="onClick">A</button>

侦听器

侦听数据源类型

watch的第一个参数可以是不同形式的“数据源”:它可以是一个 ref (包括计算属性)、一个响应式对象、一个getter函数、或多个数据源组成的数组:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
const x = ref(0)
const y = ref(0)

// 单个 ref
watch(x, (newX) => {
console.log(`x is ${newX}`)
})

// getter 函数
watch(
() => x.value + y.value,
(sum) => {
console.log(`sum of x + y is: ${sum}`)
}
)

// 多个来源组成的数组
watch([x, () => y.value], ([newX, newY]) => {
console.log(`x is ${newX} and y is ${newY}`)
})

这里有一只爱丽丝

希望本文章能够帮到您~


学习Vue时候随手写的东西-2
https://map1e-g.github.io/2022/11/23/vue-learning-2/
作者
MaP1e-G
发布于
2022年11月23日
许可协议