Vue指令是模板与逻辑交互的桥梁,本质是编译时识别属性并绑定响应式行为;v-if销毁DOM、v-show仅切样式;v-for必须用唯一key;v-model是:value+@input语法糖;v-on/v-bind支持修饰符和动态绑定。
Vue.js 的指令是模板层与逻辑层交互的桥梁,理解它们的原理和用法,比死记语法更重要。 指令不是魔法,本质是 Vue 在编译模板时识别特定属性(如 v-if、v-model),并绑定对应的数据响应式行为。掌握核心指令,能写出更清晰、可维护的组件逻辑。
v-if 是“真正”的条件渲染——条件为假时,对应 DOM 元素被完全销毁和重建;v-show 只是切换元素的 display: none 样式,元素始终保留在 DOM 中。因此:
v-show
v-if 更节省内存v-else 和 v-else-if 必须紧跟在 v-if 或另一个 v-else-if 后,不能用在独立标签上v-if 和 v-for(官方不推荐),应改用计算属性过滤列表v-for 支持遍历数组、对象、数字甚至字符串。但必须为每个循环项提供唯一的 key,这不是可选项:
key 告诉 Vue 虚拟 DOM 如何追踪节点身份,缺失或使用 index 作 key 会导致状态错乱(如输入框内容错位、动画异常)user.id),而非 :key="index"
(value, key, index);遍历数组时为 (item, index) 或 (item, index, array)
push()、splice()、sort() 等 Vue 检测到的方法,避免直接赋值 arr[0] = xxx
v-model 是语法糖,底层等价于 :value + @input(或 @update:modelValue 在 Vue 3)。它让表单控件与数据自动同步:
立即学习“前端免费学习笔记(深入)”;
input 事件;checkbox 和 radio 特殊处理值类型(布尔/字符串).lazy 改为监听 change;.number 自动转数字;.trim 自动去首尾空格v-model,需声明 modelValue prop 并触发 update:modelValue 事件(Vue 3);Vue 2 使用 value prop + input 事件v-model(如不同 prop)可用 v-model:xxx 语法(Vue 3)或 model 选项(Vue 2)v-on(简写 @)和 v-bind(简写 :)是基础但高频的指令:
@click.stop.prevent 相当于阻止冒泡+阻止默认行为,比在方法里写 e.stopPropagation(); e.preventDefault() 更简洁@keyup.enter)或自定义键码(@keyup.13),Vue 3 还支持 @keyup.page-down 等语义化写法v-bind 可绑定单个属性(:id="userId"),也可用对象批量绑定(:class="{ active: isActive, 'text-danger': hasError }")或数组(:class="[activeClass, errorClass]"):[dynamicPropName]="value",适合构建高度复用的封装组件