精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

自動 Import 工具,前端打字員的自我救贖

新聞 前端
作為一個前端打字員,一個經常遇到的場景就是在 路由文件中引入模塊 ,總是做這么機械的事情無異于消耗我這個 前端打字員 的壽命,不能忍,遂寫個工具。

自動 import 工具

作為一個前端打字員,一個經常遇到的場景就是在 路由文件中引入模塊 ,比如這樣

在 router/index.js 中寫入

import Vue from 'vue'
import Router from 'vue-router'

const About = () => import('../pages/About.vue')
const Home = () => import('../pages/Home.vue')

Vue.use(Router)
...

如果修改了模塊的名字,增加了模塊或者刪除了模塊,就需要重新修改這個路由文件

總是做這么機械的事情無異于消耗我這個 前端打字員 的壽命

不能忍,遂寫個工具

整理思路如下

其中,監視目錄下文件的變動依靠的是 node API 中 fs.watch(filename[, options][, listener])

替換目標文件中引入模塊的部分,則是通過正則來實現

在這里五星推薦一個驗證正則是否正確的網站, regexr

代碼實現

監視包含模塊的目錄

fs.watch(dir, {
  recursive: true // 目錄下子目錄也被監視
}, (event, filename) => { 
// event 是文件變動的類型,添加文件、刪除文件和修改文件名都是'rename' 事件
// filename 是變化的文件或目錄
  if(event === 'rename'){ // 判斷文件變動類型
    
  }
})

當發生 rename 事件后,需要重新獲得目錄下( from )所有的模塊,包括模塊名 moduleName,模塊文件相對于引用模塊文件( to )的相對路徑 modulePath ,將它們存入變量 modules 中

實際項目中,模塊通常都是 .vue 文件,或者 .jsx 文件,因此只將這些作為模塊,在路由文件中引用

另外有些模塊文件因為各種原因,希望人工引入,而不被 watch ,這樣的文件存入 excludeArr 中

const _ = require('lodash')
let excludeArr = [...]
let modules = []
let extname = '.vue'
let from = './src/pages'
let to = './src/router/index.js"'

const mapDir = d => {
    // 獲得當前文件夾下的所有的文件夾和文件
    const [dirs, files] = _(fs.readdirSync(d)).partition(p =>
        fs.statSync(path.join(d, p)).isDirectory()
    )

    // 映射文件夾
    dirs.forEach(dir => {
        modules.concat(mapDir(path.join(d, dir)))
    })

    // 映射文件
    files.forEach(file => {
        // 文件后綴名
        let filename = path.join(d, file)
        if (path.extname(file) === extname) {
            if (!excludeArr.includes(path.resolve(__dirname, filename))) {
                let moduleName = path.basename(file, extname)
                // 若存在 -
                if (moduleName.match('-')) {
                    moduleName = moduleName.replace(
                        /(-)(.{1})/,
                        (match, p1, p2, offset, string) => p2.toUpperCase()
                    )
                }
                modules.push({
                    moduleName,
                    modulePath: path.relative(path.dirname(to), filename)
                })
            }
        }
    })
}

生成好新的待引入的模塊后,接下來就是在路由文件中,將對應的內容替換掉

所以需要讀寫文件以及正則替換

const regex = /\/\*\sautoImport(.*\n)*\/\*\sautoImport\s\*\//g
                let importStr = ''
                modules.forEach((m, index) => {
                    importStr =
                        importStr +
                        fillTemplate(template, m.moduleName, m.modulePath) +
                        (cache.length - 1 === index ? '' : '\n')
                })
                fs.readFile(to, 'utf8', (err, data) => {
                    if (err) return console.log(err)
                    let result = ''
                    if (data.match(regex)) {
                        result = data.replace(
                            regex,
                            `/* autoImport */
${importStr}
/* autoImport */`
                        )
                    } else {
                        /* ***插入在文件***的import插入 */
                        result = data.replace(
                            /(.*import.*)(\n)([^(import)])/,
                            (match, p1, p2, p3, offset, string) => {
                                return `${p1}
/* autoImport */
${importStr}
/* autoImport */
${p3}`
                            }
                        )
                    }

                    fs.writeFile(to, result, 'utf8', err => {
                        if (err) return console.log(err)
                    })
                })

其中 /\/\*\sautoImport(.*\n)*\/\*\sautoImport\s\*\//g 是用于匹配兩段注釋 /* autoImport */ 及其中間的內容

import Vue from 'vue'
import Router from 'vue-router'
/* autoImport */
const About = () => import('../pages/About.vue')
const Home = () => import('../pages/Home.vue')
/* autoImport */

Vue.use(Router)

當***次使用,沒有 /* autoImport */ 時,就需要在***一個 import 后面,插入引入的模塊

data.replace( 
                            /(.*import.*)(\n)([^(import)])/, 
                            (match, p1, p2, p3, offset, string) => { 
                                return `${p1} 
/* autoImport */ 
${importStr} 
/* autoImport */ 
${p3}` 

在這里還可以自定義了引入模塊的方式,例如懶加載, "const moduleName = () => import(modulePath)"

const template = "const moduleName = () => import(modulePath)"
const fillTemplate = (template, moduleName, modulePath) =>
    template
        .replace('moduleName', moduleName)
        .replace('modulePath', `'${modulePath}'`)

為了工具的靈活性,把可配置項寫成json文件的形式

{
    "extname": ".vue",
    "from": "src/pages",
    "to": "src/router/index.js",
    "template": "const moduleName = () => import(modulePath)",
    "exclude": [
        "./src/pages/login.vue",
        "./src/pages/404.vue",
        "./src/pages/overall/**",
        "./src/pages/account-result/**"
    ]
}

然后通過以下的方式來獲得

const config = fs.readFileSync('./autoImport.json')
const { extname, from, to, template, exclude } = JSON.parse(config)

后記

下一步準備把這個工具寫成webpack的插件,名字我都起好了, AutoImportPlugin ,先在github上占了個坑, 順手給顆星,不用改Bug

同時準備用更加成熟的模塊 chokidar 來代替原生的 watch

工具有問題提issue啊

責任編輯:張燕妮 來源: 推酷
相關推薦

2019-11-14 18:47:06

Python程序員人生第一份工作

2019-11-13 14:16:09

Python開發工具

2013-10-21 09:53:50

Windows 8.1微軟

2020-07-24 09:44:03

安全駐場工程師網絡安全IT安全

2012-03-07 17:34:28

TransPhone

2019-04-18 08:56:33

互聯網996裁員

2009-06-17 10:39:01

互聯網

2015-07-17 08:27:19

EMMBYOD

2015-07-20 09:11:19

企業移動管理EMMBYOD安全

2019-10-21 09:20:36

安卓系統Android

2011-12-27 16:31:27

程序員

2018-06-29 15:21:12

中興程序員區塊鏈

2016-09-06 14:48:36

存儲

2017-10-20 17:21:16

華為

2013-07-04 13:50:14

2019-04-16 08:35:05

Selenium ID功能測試自動化

2024-03-08 13:11:05

前端自動化工具

2013-11-11 09:26:50

編程思考

2018-05-23 00:06:25

無人貨架智能貨架供應鏈

2025-03-24 00:00:00

點贊
收藏

51CTO技術棧公眾號

在线精品亚洲欧美日韩国产| 天堂成人在线观看| 久久综合88| 欧美一级精品大片| 男人添女人下部视频免费| 亚洲欧美日韩免费| 久久av资源网| 91精品国产高清久久久久久久久| 亚洲精品成人无码熟妇在线| 91麻豆精品| 污片在线观看一区二区| 亚洲国产一区二区三区在线播| 国产成年妇视频| 日韩中文字幕1| 久久99亚洲热视| 少妇光屁股影院| 伊人www22综合色| 在线观看免费亚洲| www精品久久| 免费黄色网页在线观看| 99精品久久久久久| 国产日韩精品在线观看| 成人毛片18女人毛片| 正在播放日韩欧美一页| 在线a欧美视频| 国产人妻黑人一区二区三区| 亚洲综合伊人| 欧日韩精品视频| 国产超级av在线| 污污在线观看| 综合电影一区二区三区| 色就是色欧美| 加勒比一区二区三区在线| 国产成人免费网站| 91色视频在线导航| 在线免费av片| 日韩av一级片| 欧美亚洲另类在线| 日本一级一片免费视频| 欧美日韩国产色综合一二三四| 日韩中文在线中文网在线观看| 欧美 变态 另类 人妖| 国产成人在线中文字幕| 日韩一区二区精品在线观看| 中文字幕线观看| 天天综合在线观看| 欧美中文字幕一二三区视频| 黄色片一级视频| 中日韩脚交footjobhd| 五月激情综合色| 久久久久久久久久久99| wwwww亚洲| 亚洲电影第三页| 国产欧美日韩小视频| 美女精品导航| 亚洲国产欧美另类丝袜| 成人黄色大片网站| 天堂资源在线| 色婷婷久久久综合中文字幕| 久久久久久香蕉| 国产69精品久久久久9999人| 欧美久久久久久久久| 天堂av.com| 天堂av一区| 精品国产精品网麻豆系列| 中文字幕一区二区三区人妻在线视频 | 9国产精品午夜| 亚洲国产日韩欧美在线99| 91视频啊啊啊| 精品国内自产拍在线观看视频 | 国产精品久久久久久久久久久久午夜片| 国产精品热久久| 国产精品99久久久久久似苏梦涵| 操人视频欧美| 三级无遮挡在线观看| 国产欧美日韩精品a在线观看| 亚洲免费视频一区| 在线三级电影| 午夜精品123| 污污的网站18| 日本久久伊人| 国产手机视频精品| 五月天精品在线| 中文字幕亚洲精品乱码| 97在线观看免费| 中文在线免费看视频| 国产成人在线色| 免费在线成人av| 国产原创精品视频| 欧美日韩激情美女| 日本中文字幕二区| 少妇久久久久| 久久伊人精品天天| 天天操夜夜操视频| 国产一区日韩二区欧美三区| 精品一区日韩成人| jizzjizz亚洲| 色婷婷综合久久久中文字幕| 美女被艹视频网站| 欧美精品一区二区三区精品| 超薄丝袜一区二区| 无码人妻一区二区三区免费| 国产精品99久久久久久有的能看| 精品视频一区二区三区四区| 久久77777| 色久综合一二码| 亚洲v在线观看| 日韩激情免费| 日本精品久久久| 国产日韩精品suv| 国产日韩欧美精品一区| 成年人网站国产| 精品午夜av| 日韩亚洲一区二区| 欧美 日韩 精品| 国产69精品久久久久毛片| 亚洲午夜精品久久| 欧美大片免费观看网址| 精品久久久久久久久久久院品网| 羞羞在线观看视频| 久久午夜精品| 国产在线播放一区二区| 日韩激情av| 欧美一区二区在线免费观看| 国产1区2区在线观看| 亚洲一区国产| 国产精品日韩一区二区三区| 国产二区三区在线| 欧美日韩中文另类| 亚洲自拍偷拍图| 久久国产日韩| 精品一区久久久| 成年男女免费视频网站不卡| 日韩精品一区二区三区视频| 一级片一级片一级片| 蜜臀av性久久久久av蜜臀妖精| 欧美一区二区影视| 伊人久久精品一区二区三区| 亚洲国产欧美一区二区三区同亚洲| 国模无码国产精品视频| 国产麻豆91精品| 免费观看黄色大片| 成人在线精品| 操人视频在线观看欧美| 精品国产999久久久免费| 亚洲女与黑人做爰| 人妻少妇偷人精品久久久任期| 久久精品欧美一区| 91视频最新| 久久香蕉一区| 亚洲精品福利免费在线观看| 国产区在线观看视频| 久久夜色精品国产噜噜av| 能在线观看的av| 国产精品片aa在线观看| 国产精品久久久久不卡| 婷婷激情在线| 日韩一区和二区| 国产一级大片在线观看| 盗摄精品av一区二区三区| 久久人人爽人人爽人人av| 精品网站aaa| 日本精品在线视频| 色综合久久影院| 日韩视频免费观看高清完整版在线观看 | 国产成人一区二区三区影院| 国产精品国产福利国产秒拍| 五月婷婷在线视频| 欧美成人精品福利| 国产三级av片| 国产精品久久久爽爽爽麻豆色哟哟| 91欧美视频在线| 女生裸体视频一区二区三区| 国产精品亚洲综合| 偷拍视频一区二区三区| 久久精视频免费在线久久完整在线看| 国产不卡av在线播放| 激情成人在线视频| 国产精品理论在线| 国产不卡在线播放| 亚洲熟妇av一区二区三区| 日韩免费视频| 国产精品v欧美精品∨日韩| 亚洲欧美韩国| 久久国产精品电影| 日本a一级在线免费播放| 欧美日韩高清一区二区不卡 | 在线视频自拍| 亚洲成人久久久久| 亚洲视频在线观看一区二区 | 久久精品国产精品亚洲| 天堂网在线播放| 欧美精品日韩一本| 精品国产免费观看| 日韩久久一区二区| 黄色在线观看av| 国产精品一区二区三区99| 免费日韩视频在线观看| 欧美国产高清| 五月婷婷一区| 色综合久久中文| 999国内精品视频在线| 日韩欧美精品一区二区综合视频| 欧美极品第一页| 91在线看黄| 亚洲精品在线不卡| 懂色av成人一区二区三区| 欧美午夜精品一区| 国产精品va无码一区二区三区| 亚洲美女偷拍久久| 日韩精品电影一区二区三区| av欧美精品.com| 韩国三级hd中文字幕有哪些| 免费在线看成人av| 日本熟妇人妻xxxxx| 精品电影一区| 欧美做受777cos| 91亚洲一区| 日韩女优中文字幕| 天天躁日日躁狠狠躁欧美| 福利视频久久| 自拍偷拍亚洲图片| 国产精品无码专区在线观看| 成人亚洲欧美| 欧美亚洲一区在线| 成人免费网站观看| 国内精品中文字幕| 国产探花视频在线观看| 久久成人国产精品| 国产原厂视频在线观看| 久久久国产精品免费| seseavlu视频在线| 国产亚洲欧美另类中文| 免费在线性爱视频| 亚洲女成人图区| 青青草免费在线视频| 亚洲精品国精品久久99热 | 成人综合婷婷国产精品久久 | 国产精品免费aⅴ片在线观看| 中文字幕第4页| 久久一区二区视频| 在线观看日韩精品视频| 9色porny自拍视频一区二区| 在线中文字日产幕| 成人精品高清在线| 亚洲久久久久久| 26uuu国产电影一区二区| 国产成人无码一区二区在线观看| 99精品一区二区| 国产肉体xxxx裸体784大胆| 26uuu精品一区二区三区四区在线| 中文字幕一区二区久久人妻网站| 91小视频在线免费看| 国产精品揄拍100视频| 久久精品无码一区二区三区| 极品久久久久久久| 最好看的中文字幕久久| 在线看的片片片免费| 亚洲一区在线视频观看| 久久久精品视频免费| 午夜久久久久久电影| 可以免费在线观看的av| 在线精品国精品国产尤物884a| 伊人久久成人网| 欧美一级欧美三级| 国精产品一品二品国精品69xx | 欧美喷潮久久久xxxxx| 国产麻豆一精品一男同| 欧美mv和日韩mv国产网站| 色窝窝无码一区二区三区| 亚洲免费视频一区二区| а天堂8中文最新版在线官网| 色琪琪综合男人的天堂aⅴ视频| 最新黄网在线观看| 91国内产香蕉| 久久国产三级| 狠狠色噜噜狠狠狠狠色吗综合| 国产日韩视频在线| 欧美大片免费播放| 久久久成人网| 亚洲色图欧美自拍| 久久综合色之久久综合| 亚洲少妇xxx| 精品国产精品自拍| 国产又粗又猛又爽又黄视频| 亚洲精品成人免费| 日本电影在线观看网站| 久久久久免费精品国产| 成人免费网站www网站高清| 97久草视频| 狠狠做六月爱婷婷综合aⅴ| 黄色片免费在线观看视频| 久久婷婷一区| 老熟女高潮一区二区三区| 日本一区二区三区在线不卡| 国产主播在线观看| 欧美日韩三级一区二区| 天堂在线资源库| 美日韩精品视频免费看| 亚洲成人av观看| 国产日韩欧美精品| 午夜影院欧美| 成人一区二区三| 成人国产精品免费观看| 欧美日韩黄色网| 色综合网站在线| 天堂成人在线观看| 色综合91久久精品中文字幕| 免费成人高清在线视频| 欧美日韩综合久久| 亚洲黄色影院| 少妇性l交大片7724com| 国产精品网站在线播放| 免费在线不卡视频| 亚洲国产精品人久久电影| 超碰在线观看免费版| 国产精品视频免费观看www| 欧美尿孔扩张虐视频| 日韩a级黄色片| 国产一区二区三区综合| 日本免费网站视频| 欧美色图第一页| 国产最新视频在线观看| 秋霞av国产精品一区| 牛牛影视一区二区三区免费看| 亚洲中文字幕无码一区二区三区| 久久se这里有精品| 伊人久久久久久久久久久久久久| 在线观看91精品国产入口| 青青青草原在线| 欧美亚洲国产成人精品| 精品精品国产毛片在线看| 无码熟妇人妻av在线电影| 国产精品1024久久| 久久久久久视频| 日韩一级大片在线| 永久免费网站在线| 亚洲综合在线中文字幕| 欧美激情第8页| 久久久久中文字幕亚洲精品| 一区二区三区精品| 成人精品在线播放| 亚州国产精品久久久| 国产精品午夜av| 春日野结衣av| 久久亚洲一区二区三区明星换脸| 久久国产视频精品| 一区二区成人av| 欧美极品在线| 97超碰免费观看| 国产精品小仙女| 国产在线观看免费视频今夜| 亚洲福利视频在线| 亚洲精品日产| 日日夜夜精品网站| 久久精品国产精品亚洲综合| 可以免费看av的网址| 欧美一区二区三区色| www.8ⅹ8ⅹ羞羞漫画在线看| 欧美日韩国产精品一区二区| 日本 国产 欧美色综合| 暗呦丨小u女国产精品| 日韩欧美国产不卡| 男人久久天堂| 亚洲福利av在线| 国产精品综合一区二区| 欧美三级韩国三级日本三斤在线观看| 日韩成人在线视频网站| 日韩不卡视频在线观看| 国产精品一区在线免费观看| 成人动漫在线一区| 成人毛片一区二区三区| 久久视频在线视频| 网红女主播少妇精品视频| 丁香婷婷激情网| 一区二区三区国产豹纹内裤在线| 污视频软件在线观看| 国产精品久久久久福利| 国产精品v日韩精品v欧美精品网站| 国产精品久久久免费观看| 欧美日韩精品一区二区三区四区| 日本高清在线观看视频| 欧美午夜精品久久久久久蜜| 国内精品伊人久久久久av一坑| 日韩免费av片| 日韩在线观看网站| 日本午夜精品| 九九热视频免费| 欧美性猛交xxxx免费看漫画| av大片在线播放| 国产欧美日韩伦理| 久久99精品久久久久婷婷| 久草国产精品视频| 久久久av一区| 欧洲专线二区三区| 亚洲成年人av| 91精品国产福利| 最新日韩一区| 国产91美女视频| 一区二区成人在线观看|