vue_15 自定義全局指令

使用vue自定義全局指令,在加載頁(yè)面的時(shí)候自動(dòng)讓光標(biāo)聚焦到輸入框

使用Vue.directive() 定義全局的指令,
語(yǔ)法:
Vue.directive("focus",對(duì)象) 這樣定義的是全局的,如果需要定義私有的,就在vue實(shí)例中,添加directives字段
自定義的命令也是可以傳參的.不過(guò)獲取的形參是一個(gè)對(duì)象,需要使用.value拿到你傳的值,你也可以打印形參查看數(shù)據(jù)的結(jié)構(gòu)
參數(shù):focus就是你定義的指令名,不過(guò)在調(diào)用的時(shí)候需要在前面加上 v-
所有vue的指令都是 v- 開(kāi)頭的
參數(shù):對(duì)象 這個(gè)對(duì)象里面包含有與你定義的指令相關(guān)的函數(shù),常用的bind , inserted ,updated

vue指令函數(shù)也可以縮寫(xiě).使用縮寫(xiě)的時(shí)候, 相當(dāng)于函數(shù)應(yīng)用在了bind和update里面
形式如:
directives:{
"focus1":function(el){}
}
// bind和update會(huì)同時(shí)綁定這個(gè)這個(gè)函數(shù),如果需求兩個(gè)綁定不一樣,就不能這么寫(xiě)了

代碼示例

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <script src="../util/vue-2.4.0.js"></script>
</head>
<body>
<div id="test">
    <input type="text" v-focu="[100,200]"/><br/>

</div>

<div id="test1">
    <input type="text" v-focus1="100"/>
</div>
<script>
    Vue.directive("focu",{
        // 注:在每個(gè)函數(shù)中,第一個(gè)參數(shù)永遠(yuǎn)是el,表示被綁定了指令的那個(gè)元素,這是el參數(shù)是一個(gè)原生js對(duì)象
        bind: function (el) { //每當(dāng)指令綁定到元素上的時(shí)候會(huì)立即執(zhí)行這個(gè)bind函數(shù),只執(zhí)行一次
            // 在元素剛綁定了指令的時(shí)候,還沒(méi)有插入到DOM中去,這時(shí)候,調(diào)用focus方法沒(méi)有作用
            el.focus();
        },
        inserted: function (el,data) {//當(dāng)元素插入到DOM中的時(shí)候,會(huì)執(zhí)行inserted函數(shù)
            el.focus();
            console.log(data.value[0],data.value[1])
        },
        updated: function (el) { // 當(dāng)組件更新的時(shí)候,會(huì)執(zhí)行updated ,可能會(huì)執(zhí)行多次

        }
    });
    var vm1 = new Vue({
        el:"#test"

    });
    var vm2 = new  Vue({
        el:"#test1",
        directives:{
            "focus1":{
                inserted: function (el, arg1) {
                    console.log(arg1.value)
                }
            }
        }
    })
</script>
</body>
</html>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容