<el-input ref="agin" v-select="true" v-model="insertInfoBcbd"></el-input>
1、加载完成后默认为选中状态(选中和聚焦效果不能并存,insertInfoBcbd一定要赋予初始值,否则不能实现默认选中,只能默认聚焦)
directives自定义指令,定义在data同级
生命周期:
- bind:只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置
- inserted:被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)。
- update:所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新 。
- componentUpdated:指令所在组件的 VNode 及其子 VNode 全部更新后调用。
- unbind:只调用一次,指令与元素解绑时调用。
生命周期函数中的参数:
- el: 指令所绑定的元素,可以用来直接操作 DOM,就是放置指令的那个元素。
- binding: 一个对象,里面包含了几个属性,详情请见官方文档。
- vnode:Vue 编译生成的虚拟节点。
- oldVnode:上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用
directives: {
select:{//默认选中
inserted:function (el,binding) {
el.querySelector('input').select();
//因为el-input在input标签外面还包了其他标签,所以要通过querySelector选中input框
}
},
focus:{//默认聚焦
inserted:function (el,binding) {
el.querySelector('input').focus();
}
}
}
2、二次自动选中(在需要二次自动选中的地方写如下代码即可)
this.$nextTick( () =>{
this.$refs.agin.select()//自动选中
this.$refs.agin.focus()//自动聚焦
} )