詳解Vue This$Store總結(jié)
開(kāi)發(fā) VueThis$Store 一些技巧
上次答應(yīng)一個(gè)讀者介紹下開(kāi)發(fā)此插件的一些原理和技巧,在此也一并做下總結(jié)了。
基本工具
1 正則表達(dá)式,正則表達(dá)式大家都不陌生,正則表達(dá)式的優(yōu)點(diǎn)就是速度快,對(duì)于一個(gè)代碼補(bǔ)全的插件,用戶肯定希望更快的得到反饋,測(cè)試了 1000 行的 vue 文件匹配全部的 mapXXX() 之類的 api 字符串也只是用了 1ms 都不到的時(shí)間,但是缺點(diǎn)也非常明顯,他是上下文無(wú)關(guān)的,比如說(shuō)
mapState({
a: state => state.test,
});
這樣一段代碼,我們可以使用 vscode 的 api 當(dāng)觸發(fā)了補(bǔ)全后,用 /\bmapState\(([\'\"](.*)[\'\"](?:,\s*)?)?((\[[\s\S]*?\])|(\{[\s\S]*?\}))?\s*\)/g 捕獲到上面這段代碼,但是朋友你還要考慮的是,函數(shù)有三種方法
mapState({
a: state => state.test,
b(s) {
return s.test;
},
c: function(s) {
return s.test;
},
});
你怎么使用正則表達(dá)式捕獲到 a, b, c 三個(gè)屬性并且拿到三個(gè)函數(shù)的第一個(gè)參數(shù)呢,不排除有人能做到,但是可能會(huì)耗費(fèi)不少時(shí)間吧。
2 Abstract Syntax Tree(以下用簡(jiǎn)寫(xiě) ast),我這里是使用時(shí) babel 的 parser babylon ,ast 和正則表達(dá)式的優(yōu)缺點(diǎn)有點(diǎn)互補(bǔ)的意思,parser 缺點(diǎn)是相對(duì)慢,但是通過(guò) parser 得到的 ast 對(duì)于一代碼的描述更加精確,你可以得到函數(shù)的參數(shù),等很多信息,這里了就不科普,掘金有很多介紹 ast 的文章,這里強(qiáng)烈推薦這個(gè)網(wǎng)站astexplore,你可以在網(wǎng)站上練習(xí),做一些很酷的事情。
開(kāi)工
有了這兩種工具,我們就可以開(kāi)始寫(xiě)代碼啦,既然兩種工具的優(yōu)缺點(diǎn)是互補(bǔ)的,我就想能不能將他們結(jié)合起來(lái)使用,最終想到的比較理想的方法就是,使用正則表達(dá)式捕獲 mapXXX 這種工具函數(shù),找到所有匹配的代碼段以后使用 parser 獲取 ast,在來(lái)分析函數(shù)的參數(shù),因?yàn)?ast 里信息非常豐富,我們可以獲取到是哪種的函數(shù),以及函數(shù)的第一個(gè)參數(shù),這樣用戶使用 . 觸發(fā)補(bǔ)全時(shí),即使用了 state 的簡(jiǎn)寫(xiě) s,我們?nèi)匀豢梢越o出正確的建議。
但是我們要獲取 store 中所有的定義,就必須找到 store 的入口文件,怎樣找到 store 的入口文件呢?還記得我們平時(shí)是怎么注入 store 的么?
import Vue from 'vue';
import App from './App.vue';
import store from './store';
new Vue({
render: h => h(App),
store,
}).$mount('#app');
我們只要通過(guò)parser的到這段文本的ast,就可以獲取到store的相對(duì)路徑了,獲取到store的相對(duì)路徑了之后就可以獲取到vuex中的實(shí)例中的配置對(duì)象,獲取到配置對(duì)象就一步一步向下獲取到所有,mutations,state,getters,modules,遍歷所有module,其實(shí)每一個(gè)module就是一個(gè)vuex實(shí)例的配置對(duì)象,我們就可以遞歸以上的代碼,獲取所有的store代碼了,上個(gè)流程圖。

當(dāng)然我們?cè)谡{(diào)用的時(shí)候要注意一些事項(xiàng),比如 對(duì)象可能從外部引入
import Vue from 'vue';
import Vuex from 'vuex';
import state from './state';
Vue.use(Vuex);
export default new Vuex.Store({
state,
});
可能就以屬性的形式直接定義
export default {
account: {
namespaced: true,
state: {
number: 31
},
getters: {
testlen: state => state.number.length
},
mutations: {
change(state, { number }) {
state.number = number;
}
}
}
};
也可能先定義,在以對(duì)象屬性簡(jiǎn)寫(xiě)的形式引入。
const state = {name: 'jack'}
export default {
state: state
}
總結(jié)
以上只是將我制作這個(gè)插件,用到的工具和思想和大家分享下,也是對(duì)這次開(kāi)發(fā)的總結(jié)吧,具體的實(shí)現(xiàn)請(qǐng)移步這里
反思
開(kāi)源這個(gè)vscode插件以后,取得的用戶數(shù)量還是沒(méi)有達(dá)到自己的理想水平,自己下來(lái)也有反思
- 前端可以選擇的ide有很多,并不是每個(gè)人都用vscode
- 我這個(gè)插件能帶來(lái)的功能有限,可能在一個(gè).vue文件中就用到一兩次vuex中的數(shù)據(jù),裝這個(gè)插件能帶來(lái)的體驗(yàn)提升有限,并不能和vetur這種涵蓋了所有常用的功能相比。
之前也有掘金用戶想我提建議,可以考慮和vetur合并,但是從目前來(lái)看好像并不是有很多人需要這個(gè)插件,我還是先盡力維護(hù)好這個(gè)項(xiàng)目吧。
一些可能對(duì)你有幫助的網(wǎng)站
vscode插件官方文檔,可以手把手教你做一個(gè)vscode插件:vscode官方文檔
astexplore:你可以在這里自由練習(xí)主流parser的用法:可以看到ast的結(jié)構(gòu) :astexplore
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue綁定對(duì)象與數(shù)組變量更改后無(wú)法渲染問(wèn)題解決
這篇文章主要介紹了Vue綁定對(duì)象與數(shù)組變量更改后無(wú)法渲染問(wèn)題解決,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
vue路由傳參頁(yè)面刷新參數(shù)丟失問(wèn)題解決方案
這篇文章主要介紹了vue路由傳參頁(yè)面刷新參數(shù)丟失問(wèn)題解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
vue 通過(guò) mqtt 實(shí)現(xiàn)實(shí)時(shí)接收消息的操作方法
?MQTT是一種基于發(fā)布/訂閱模式的輕量級(jí)消息協(xié)議,適用于硬件性能有限的遠(yuǎn)程設(shè)備和網(wǎng)絡(luò)狀況不佳的環(huán)境,這篇文章主要介紹了vue 通過(guò) mqtt 實(shí)現(xiàn)實(shí)時(shí)接收消息,需要的朋友可以參考下2024-12-12
vue項(xiàng)目前端知識(shí)點(diǎn)整理【收藏】
本文是小編給大家收藏整理的關(guān)于vue項(xiàng)目前端知識(shí)點(diǎn),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05
Vue引用第三方datepicker插件無(wú)法監(jiān)聽(tīng)datepicker輸入框的值的解決
這篇文章主要介紹了Vue引用第三方datepicker插件無(wú)法監(jiān)聽(tīng)datepicker輸入框的值的解決,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
Vue遞歸實(shí)現(xiàn)樹(shù)形菜單方法實(shí)例
學(xué)習(xí)vue有一段時(shí)間了,最近使用vue做了一套后臺(tái)管理系統(tǒng),其中使用最多就是遞歸組件,下面這篇文章主要給大家介紹了關(guān)于Vue利用遞歸實(shí)現(xiàn)樹(shù)形菜單的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-11-11
Vue項(xiàng)目保持element組件同行,設(shè)置組件不自動(dòng)換行問(wèn)題
這篇文章主要介紹了Vue項(xiàng)目保持element組件同行,設(shè)置組件不自動(dòng)換行問(wèn)題。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
Vue3中實(shí)現(xiàn)微信掃碼登錄的步驟和代碼示例
在 Vue 3 中實(shí)現(xiàn)微信掃碼登錄,涉及到前端生成二維碼、監(jiān)聽(tīng)微信回調(diào)以及與后端的交互,本文給大家介紹了一個(gè)詳細(xì)的實(shí)現(xiàn)步驟和代碼示例,對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-07-07

