在Vue中要給input設(shè)置焦點,需要注冊自定義指令。
Vue.directive('focus', function (el, option) {
var defClass = 'el-input', defTag = 'input';
var value = option.value || true;
if (typeof value === 'boolean')
value = { cls: defClass, tag: defTag, foc: value };
else
value = { cls: value.cls || defClass, tag: value.tag || defTag, foc: value.foc || false };
if (el.classList.contains(value.cls) && value.foc)
el.getElementsByTagName(value.tag)[0].focus();
});
由于ElementUI中的el-input是一個自定義組件,并非input元素,所以需要傳入組件的class和tag名稱來定位組件內(nèi)的原生input,并調(diào)用input的focus方法來獲得焦點。
使用的時候,分兩種情況:
頁面中只有一個組件用到focus指令
<el-input v-focus="true"></el-input>
頁面中有多個組件用到focus指令
此時,需要傳入class和tag來定位具體的元素
<el-input-number v-focus="{ cls: 'el-input-number',tag: 'input', foc: focus.count }" v-on:blur="focus.count=false"></el-input-number>
補充說明:
在實際用focus指令的過程中,需要給元素添加blur事件:
v-on:blur="focus.count=false"。失去焦點后一定要把focus指令對應(yīng)的變量置為false,否則會導(dǎo)致一些不可控的bug。
參考資料: