Vue指令修饰符

作用:借助指令修饰符,可以让指令的功能更强大。

分类:

1.按键修饰符:监测用户的案件,配合键盘事件使用。

2.事件修饰符:简化程序对于阻止冒泡、阻止默认行文的操作。

3.双向绑定指令的修饰符:可以让v-model的功能更加强大。

按键修饰符

就是按键按下的时候的约束条件,看代码:

javascript 复制代码
<template>
  <div>
    <!-- 按键修饰符 -->
    <input type="text" @keydown.enter="onKeyDown" />

  </div>
</template>

<script setup>
const onKeyDown = () => {
  console.log("onKeyDown");
};
</script>

<style scoped>
</style>

这个修饰符还有几个,就比如说,空格,删除键等,都可以加。

事件修饰符:

事件修饰符主要用的有两个,一个是prevent和stop。

prevent主要的作用就是阻止默认行为,就比如说a标签跳转指定的网站,我们就可以加prevent,阻止跳转。stop主要就是阻止冒泡,那什么是冒泡,就是子标签的父标签,都有相同的事件,就比如说点击事件,当子标签触发点击事件的时候,就会向上冒泡,父标签也会出发点击事件,这个时候就可以用stop来阻止冒泡。看代码:

javascript 复制代码
<template>
  <div>
    <!-- 按键修饰符 -->
    <input type="text" @keydown.enter="onKeyDown" />
    <!-- 事件修饰符 -->
    <a href="https://baidu.com" @click.prevent>百度一下</a>
    <div class="f1">
      <div class="f2" @click="onClick">
        <p @click="onClick2">11111</p>
      </div>
    </div>
  </div>
</template>

<script setup>
const onKeyDown = () => {
  console.log("onKeyDown");
};
const onClick=()=>{
  console.log("1111");
}
const onClick2=()=>{
  console.log("2222")
}
</script>

<style scoped>
</style>

上面是没有加stop,会有冒泡

javascript 复制代码
<template>
  <div>
    <!-- 按键修饰符 -->
    <input type="text" @keydown.enter="onKeyDown" />
    <!-- 事件修饰符 -->
    <a href="https://baidu.com" @click.prevent>百度一下</a>
    <div class="f1">
      <div class="f2" @click="onClick">
        <p @click.stop="onClick2">11111</p>
      </div>
    </div>
  </div>
</template>

<script setup>
const onKeyDown = () => {
  console.log("onKeyDown");
};
const onClick=()=>{
  console.log("1111");
}
const onClick2=()=>{
  console.log("2222")
}
</script>

<style scoped>
</style>

上面代码就不会冒泡。

双向绑定的修饰符

v-model.trim="数据" 把输入框收尾的空格去掉,再进行同步

v-mode.number="数据" 尝试将输入框的数据转成数字

v-model.lazy="数据" 当失去焦点的时候再同步数据。

这几个用法就是在v-model后面点就可以了。具体代码就不写了。

v-model指令作用在其他表单元素上。

这里说的其他表单指的是:文本域,下拉菜单,单选框,复选框,输入框。

文本域:

这个和输入框用法一样就不介绍了。

下拉菜单:

直接看代码

javascript 复制代码
<template>
<div>

  <select v-model="city">
    <option value="BJ">北京</option>
    <option value="SH">上海</option>
    <option value="GZ">广州</option>
  </select>
  
</div>
</template>

<script setup>
import {ref} from 'vue'
  const city=ref("")
</script>

<style scoped>

</style>

结果如图

可以看到,选中北京,会把value的值进行填充。

单选框

单选框没有value这个属性,所以需要手动添加直接看代码

javascript 复制代码
<template>
<div>
  <input type="radio" value="zhangsan" v-model="name">张三
  <input type="radio" value="lisi" v-model="name">李四
  <input type="radio" value="wangwu" v-model="name">王五
</div>
</template>

<script setup>
import {ref} from 'vue'
const name=ref()
  
</script>

<style scoped>

</style>

运行结果

可以看到当选中李四之后,value的值会被进行填充。

复选框

复选框有点麻烦,它有两种情况:

1.只有一个复选框:这时候v-model绑定布尔值,关联的是复选框的check属性。

2.如果有多个复选框,这时候v-model就要和数组进行绑定,但是复选框,没有value属性,所以需要手动添加。

代码如下:

第一种情况:

javascript 复制代码
<template>
<div>

  <input type="checkbox" v-model="isAgree">如果同意请勾选
</div>
</template>

<script setup>
import {ref} from 'vue'
  const isAgree=ref(false)
</script>

<style scoped>

</style>

运行结果

发现勾选之后,布尔值变成了true;

第二种情况:

javascript 复制代码
<template>
<div>
  <input type="checkbox" value="LQ" v-model="hobby">篮球
    <input type="checkbox" value="ZQ" v-model="hobby">足球
  <input type="checkbox" value="YMQ" v-model="hobby">羽毛球
  <input type="checkbox" value="PPQ" v-model="hobby">乒乓球

</div>
</template>

<script setup>
import{ref} from 'vue'
  const hobby=ref([])
</script>

<style scoped>

</style>

运行结果

相关推荐
倚栏听风雨1 天前
ts中 ?? 和 || 区别
前端
冴羽1 天前
请愿书:Node.js 核心代码不应该包含 AI 代码!
前端·javascript·node.js
我家猫叫佩奇1 天前
一款灵感源自《集合啦!动物森友会》的 UI 组件库
前端
mmmmm123421 天前
深入 DOM 查询底层:HTMLCollection 动态原理与 querySelectorAll 静态快照解析
前端·javascript
淸湫1 天前
前端JavaScript:数据类型、实例对象 、内置对象、构造函数之间的关系
javascript
weixin199701080161 天前
《TikTok 商品详情页前端性能优化实战》
前端·性能优化
卤蛋fg61 天前
vxe-table 自定义数字行主键,解决默认字符串主键与后端类型不匹配问题
vue.js
闲坐含香咀翠1 天前
告别二次登录!Web端检测并唤起Electron客户端实战
前端·客户端
岁月宁静1 天前
都知道AI大模型能生成文本内容,那你知道大模型是怎样生成文本的吗?
前端·vue.js·人工智能
别看我只是一直狼1 天前
从观察者模式到 RxJS:让复杂的异步逻辑变得优雅又舒服
javascript