vue2實現(xiàn)directive自定義指令的封裝與全局注冊流程
前言
我們在使用vue框架的時候,指令基本能夠覆蓋我們平常的工作??呻y免我們根據(jù)業(yè)務需求走總有的指令無法一步到達我們想要的結果。這個時候我們就可以自己動手手動封裝來制作一個指令用于完成我們的設計。
一、directive自定義指令介紹
1.概念:
除了 Vue 內置的一系列指令 (比如v-model或者v-show等眾多指令 之外,Vue 還允許你注冊自定義的指令 (Custom Directives)
2.作用:
豐富我們指令的功能,使我們組件具有原生指令不具備的功能作用
3.使用:
使用Vue.directive('自定義指令名',{對象中寫方法}),隨后v-自定義指令名使用(見下)
二、全局注冊使用流程
1.準備好我們需要的自定義指令
創(chuàng)建一個單獨的文件夾來存儲我們的自定義指令
比如博主的路徑:src/dynamic/index.js
export const focus = { inserted: function(dom, options) { console.log(dom, 'dom')// dom相當于$refs console.log(options, 'options')// 相當于該屬性,我們的值可以從這獲取 dom.focus() } }
我們查看我們的dom與options打印出來的是什么
可以得知:dom是當前的標簽,我們的options為我們自定義指令的屬性方法等
2.開始在main中導入該文件完成注冊功能
main.js中完成導入
// 使用循環(huán)注冊的方式 import * as directives from '@/directives' // 開始遍歷注冊 Object.keys(directives).forEach(key => { Vue.directive(key, directives[key]) }) console.log(Object.keys(directives), 'Object.keys(directives)') console.log(directives, 'directives')// 這玩意是一個對象
控制臺查看我們導入的directives是什么,發(fā)現(xiàn)是一個對象
3.完成了注冊功能開始使用
自定義指令<input v-focus="'看看我傳遞的位置是傳遞到哪里去了'" type="text">
可以看到我們傳遞給組件的值用 =" (數(shù)據(jù))" 進行傳遞,我們通過打印options.value可以獲取我們傳遞進來的數(shù)據(jù)
效果查看:當我們刷新頁面后進入直接是觸發(fā)了focus()方法
注意點:
- 導入時候 * 是通配符表示全部 as為取別名
- 使用方法為v-focus,切記加上v-進行使用
- Object.keys()獲取的是對象的鍵產生的數(shù)據(jù)用數(shù)組包裹起來,forEach()用于遍歷數(shù)組
- 值的傳遞使用value可以獲取
總結
到此這篇關于vue2實現(xiàn)directive自定義指令的封裝與全局注冊流程的文章就介紹到這了,更多相關vue2 directive自定義指令封裝與全局注冊內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
利用vue + element實現(xiàn)表格分頁和前端搜索的方法
眾所周知Element 是一套 Vue.js 后臺組件庫,它能夠幫助你更輕松更快速地開發(fā)后臺項目。下面這篇文章主要給大家介紹了關于利用vue + element實現(xiàn)表格分頁和前端搜索的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-12-12Vue.js頁面中有多個input搜索框如何實現(xiàn)防抖操作
debounce是lodash工具庫中的一個非常好用的函數(shù)。這篇文章主要介紹了Vue.js頁面中有多個input搜索框如何實現(xiàn)防抖操作,需要的朋友可以參考下2019-11-11vue中v-cloak解決刷新或者加載出現(xiàn)閃爍問題(顯示變量)
這篇文章主要介紹了vue中v-cloak解決刷新或者加載出現(xiàn)閃爍問題(顯示變量) ,需要的朋友可以參考下2018-04-04vue與iframe頁面數(shù)據(jù)互相通信的實現(xiàn)示例
這篇文章主要給大家介紹了vue與iframe頁面數(shù)據(jù)互相通信的實現(xiàn)示例,文中通過代碼示例給大家介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下2023-12-12