持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第6天
9. 事件修饰符
- 在事件处理函数中调用 event.preventDefault() 或 event.stopPropagation() 是非常常见的需求。因此, vue 提供了事件修饰符的概念,来辅助程序员更方便的对事件的触发进行控制。常见的5个事件修饰符如下:
| 事件修饰符 | 说明 |
|---|---|
| .prevent | 阻止默认行为(例如:阻止 a 链接的跳转、阻止表单的提交等) |
| .stop | 阻止事件冒泡 |
| .capture | 以捕获模式触发当前的事件处理函数 |
| .once | 绑定的事件只触发 1 次 |
| .self | 只有在 event.target 是当前元素自身时触发事件处理函数 |
语法格式如下:
<!-- 触发 click 点击事件时,阻止 a 链接的默认跳转行为 -->
<a href="https://www.baidu.com" $click.prevent="onLinkClick">百度首页</a>
10. 按键修饰符
在监听键盘事件时,我们经常需要判断详细的按键。此时,可以为键盘相关的事件添加</font color="red">按键修饰符,例如:
<!-- 只有在 key 是 enter 时调用 vm.submit() -->
<input @keyup.enter="submit">
<!-- 只有在 key 是 esc 时调用 vm.clearInput() -->
<input @keyup.esc="clearInput">
11. 双向绑定事件
vue提供了v-model双向数据绑定命令,用来辅助开发者不操作DOM 的前提下,快速获取表单的数据
<p>用户名是:{{ username }}</p>
<input type="text" v-model="username">
<p>选中的省份是:{{province}}</p>
<select v-model="province">
<option value="">请选择</option>
<option value="1">北京</option>
<option value="2">河北</option>
<option value="3">黑龙江</option>
</select>
12. v-model指令的修饰符
为了方便对用户输入的内容进行处理,vue为v-model 指令提供了 3个修饰符,分别是:
| 修饰符 | 作用 | 示例 |
|---|---|---|
| .number | 自动将用户的输入值转为数值类型 | |
| .trim | 自动过滤用户输入的首尾空白字符 | |
| .lazy | 在"change"时而非"input"时更新 |
<input type="text" v-model.number="n1">
<input type="text" v-model.number="n2">
<span>{{n1 + n2 }}</span>
13. v-if 和 v-show 的区别
实现原理不同:
- v-if指令会动态的创建或者移除DOM元素, 从而控制元素在页面上的显示与隐藏;
- v-show指令会动态为元素添加或移除style="display:none;"样式,从而控制元素的显示与隐藏;
性能消耗不同: v-if 有更高的切换开销,而v-show有更高的初始渲染开销。因此:
- 如果需要非常频繁地切换,则使用 v-show 较好
- 如果需要运行时条件很少改变,则使用 v-if 较好
13-1. 条件渲染指令
条件渲染指令用来辅助开发者按需控制DOM的显示与隐藏。条件渲染指令由如下两个:分别是
- v-if
- v-show 示例用法如下:
<div id="app">
<p v-if="networkState === 200">请求成功 --- 被 v-if 控制</p>
<p v-show="networkState === 200">请求成功 --- 被 v-show 控制</p>
</div>
13-2. v-else
V-if 可以单独使用,或配合 v-else 指令一起使用:
<div v-if="Math.random() > 0.5">
随机数大于0.5
</div>
<div v-else>
随机数小于或等于 0.5
</div>
- 注意:v-else 指令必须配合 v-if 指令一起使用,否则它将不会被识别!
13-3. v-else-if
v-else-if 指令,顾名思义,充当 v-if 的 "else-if块",可以连续使用:
<div v-if="type === 'A'">优秀</div>
<div v-else-if="type === 'B'">良好</div>
<div v-else-if="type === 'C'">一般</div>
<div v-else>差</div>
- 注意:v-else-if 指令必须配合 v-if 指令一起使用,否则它将不会被识别!
13-4. 列表渲染指令
VUE 提供了v-for列表渲染指令,用来辅助开发者基于一个数组来循环渲染一个列表结构。v-for指令需要使用item in items 形式的特殊语法,其中:
- items 是 待循环的数组
- item 是 被循环的每一项
data:{
list:[
// 列表数据
{id:1,name:'张三'},
{id:2,name:'李四'}
]
}
<ul>
<li v-for="item in list">姓名是:{{item.name}}</li>
</ul>
13-5. v-for 中的索引
v-for 指令还支持一个 可选的第二个参数,即当前项的索引。语法格式为(item,index) in items,示例代码如下:
data:{
list:[
// 列表数据
{id:1,name:'张三'},
{id:2,name:'李四'}
]
}
<ul>
<li v-for="(item,index) in list">索引是:{{index}},姓名是:{{item.name}}</li>
</ul>
- v-for 指令中的item项和index索引都是形参,可以根据需要进行重命名。例如:(user , i) in userlist
14. 使用 key 维护列表的状态
当列表的数据变化时,默认情况下,vue会尽可能的复用已存在的DOM元素,从而提升渲染的性能。但这种默认的性能优化策略,会导致有状态的列表无法被正确更新。 为了给 vue 一个提示,以便它能跟踪每个节点的身份,从而在保证有状态的列表被正确更新的前提下,提升渲染的性能。此时,需要为每项一个唯一的 key 属性:
<!-- 用户列表区域 --->
<ul>
<!-- 加 key 属性的好处: -->
<!-- 1. 正确维护列表的状态 -->
<!-- 2. 复用现有的 DOM 元素,提升渲染的性能 -->
<li v-for="user in userlist" :key="user.id">
<input type="checkbox">
姓名:{{user.name}}
</li>
</ul>
14-1. key的注意事项
- key的值只能是字符串或数字类型
- key的值必须具有唯一性(即:key的值不能重复)
- 建议把数据项id属性的值作为key的值(因为 id 属性的值具有唯一性)
- 使用index 的值当作key的值没有任何意义(因为index的值不具有唯一性)
- 建议使用 v-for 指令时一定要指定key的值(既提升性能、又防止列表状态缭乱)