Bootstrap

实现vue el-input框加载自动选中,二次自动选中

<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()//自动聚焦
    } )
;