精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

国产一二三四五区| 日韩麻豆第一页| 中文字幕久久一区| 国产黄色大片网站| 亚洲欧美日本国产专区一区| 亚洲欧美在线磁力| 欧美激情国内自拍| 91av久久| 国产精品看片你懂得| 亚洲在线视频福利| 久久av红桃一区二区禁漫| 进去里视频在线观看| 99精品视频在线观看播放| 日韩欧美资源站| 五月天亚洲综合| 亚洲一卡二卡在线观看| 自拍偷拍欧美专区| 亚洲欧美国产va在线影院| 国产一二三区av| 麻豆福利在线观看| 国产精品青草久久| 精品一区国产| 国产精品欧美激情在线| 男人天堂欧美日韩| 欧美精品在线视频观看| 男生草女生视频| 中文字幕一区日韩精品| 欧美在线三级电影| 狠狠干 狠狠操| а天堂中文在线官网| 久久伊人蜜桃av一区二区| 91在线精品视频| 久久久久久亚洲av无码专区| 国内精品久久久久久久影视蜜臀| 亚洲天堂av在线免费观看| 国产精品熟妇一区二区三区四区| 国产精品99精品一区二区三区∴| 一区二区久久久久久| 丝袜美腿玉足3d专区一区| 男人天堂av网| 国产美女视频一区| 国产精品久久久久久久久免费 | 伊人av综合网| 日本少妇xxxx| 爱爱精品视频| 日韩欧美黄色影院| 亚洲综合20p| 农村妇女一区二区| 欧美午夜不卡在线观看免费| 久久婷婷国产精品| 天堂а√在线最新版中文在线| 一区二区三区免费看视频| 黄瓜视频免费观看在线观看www | 精品一区亚洲| 成人免费在线播放| 日韩毛片在线看| 999精品免费视频| 成人自拍在线| 亚洲爱爱爱爱爱| 日本三级日本三级日本三级极| 视频精品国内| 亚洲国产精品福利| 大黑人交xxx极品hd| 欧美亚洲色图校园春色| 日韩久久午夜影院| 欧美做受xxxxxⅹ性视频| 国产精品探花在线观看| 亚洲一级片在线看| 国产黄色片在线| 亚洲一区二区三区| 欧美高清视频在线播放| 日本熟妇色xxxxx日本免费看| 亚洲激情女人| 国产97在线|日韩| 一级二级三级视频| 国产成人免费av在线| 国产成人亚洲欧美| 欧美性孕妇孕交| 欧美国产综合色视频| 中文字幕欧美日韩一区二区| 曰本三级在线| 欧美性猛交99久久久久99按摩| 日本成年人网址| 巨大黑人极品videos精品| 日韩一区二区三区免费看| 人妻 日韩 欧美 综合 制服| 亚洲精品进入| 久久久999精品免费| 久久久久亚洲av成人片| 免费日韩一区二区| 成人亚洲综合色就1024| 亚洲精品一区二区口爆| 久久久久国产精品麻豆ai换脸| 伊人久久大香线蕉av一区| 中文字幕在线有码| 亚洲欧美一区二区三| 91麻豆精品一区二区三区| 日韩在线国产| 性欧美videos高清hd4k| 日韩欧美aaa| 日韩不卡的av| 国产一区二区三区日韩精品| 欧美xxxx做受欧美| 欧产日产国产69| 国产乱码精品一区二区三区av| 久久免费一区| 五月天激情在线| 欧美在线一二三四区| 中文字幕人妻一区| 99久久婷婷| 日韩美女福利视频| 99热这里只有精品3| 久久久久久久电影| 女人帮男人橹视频播放| 欧美大陆国产| 亚洲日本aⅴ片在线观看香蕉| 麻豆精品一区二区三区视频| 日韩激情视频在线观看| 国产伦精品一区二区三区在线| 1024国产在线| 日韩欧美中文在线| 中文在线观看免费视频| 中文字幕一二三四区| 婷婷综合电影| 色与欲影视天天看综合网| 中文字幕制服诱惑| 天天干天天插天天操| 日韩高清电影一区| 久99久视频| 18+视频在线观看| 欧美日韩二区三区| 久久久久亚洲av无码a片| 日韩视频二区| 精品国产九九九| 日韩和欧美的一区| 精品亚洲第一| 色呦呦在线免费观看| 欧美日韩国产精品自在自线| 在线不卡av电影| 伊人天天综合| 国产高清一区二区三区| 18视频在线观看网站| 欧美日韩国产乱码电影| 人妻一区二区视频| 午夜在线视频观看日韩17c| 国产精品一区二区三区免费观看| 人人干在线视频| 欧美日韩在线直播| youjizz亚洲女人| 日韩国产欧美视频| 欧美日韩一区二区三区免费| 中文字幕在线视频网站| 日韩电影中文字幕在线| 青青草成人av| 久久综合av免费| 久久人妻精品白浆国产| 国产精品午夜一区二区三区| 国产精品吹潮在线观看| 邻家有女韩剧在线观看国语| 色婷婷av一区二区三区大白胸 | 神马午夜伦理影院| 国产精品亚洲四区在线观看| 欧美床上激情在线观看| www.国产视频| 偷窥少妇高潮呻吟av久久免费| 天天躁日日躁狠狠躁免费麻豆| 久久99久久久| 在线日韩欧美| 麻豆精品视频| 欧美色片在线观看| 久久激情视频免费观看| www.色播.com| 午夜日韩在线电影| 摸摸摸bbb毛毛毛片| 精品亚洲免费视频| 男人添女人荫蒂免费视频| 欧美天堂影院| 国产精品一区久久久| av免费在线观看网址| 精品国产亚洲一区二区三区在线观看| 色婷婷av国产精品| 中文字幕欧美区| 18深夜在线观看免费视频| 亚洲综合二区| 中文字幕乱码一区二区三区| 精品久久ai电影| 国产精品免费一区豆花| 伊人春色在线观看| 亚洲人精品午夜在线观看| a天堂在线视频| 欧美视频免费在线| 黑人狂躁日本娇小| 91影院在线观看| 亚洲欧美日韩精品一区| 1024日韩| 亚洲日本精品| 成人福利免费在线观看| 国产精品久久久久久久久久小说| 先锋成人av| 亚洲深夜福利在线| 亚洲国产成人一区二区| 在线观看网站黄不卡| 亚洲午夜无码av毛片久久| 97超碰人人模人人人爽人人爱| 国产精品视频你懂的| 怡红院一区二区| 久久99在线观看| 精品99在线视频| 欧美午夜一区| 亚洲欧美日韩在线综合| 久久a爱视频| 亚洲影视九九影院在线观看| 亚洲人免费短视频| 91国内精品久久| 性欧美video高清bbw| 色妞欧美日韩在线| 四虎影院在线播放| 欧美成人a∨高清免费观看| 国产黄色免费视频| 日韩欧美黄色动漫| 国产午夜福利一区二区| 亚洲欧美一区二区三区国产精品| 中文字幕在线观看网址| 国产成人精品网址| 久久精品国产99久久99久久久| 日日骚欧美日韩| 欧美日韩二三区| 亚洲福利国产| 女人帮男人橹视频播放| 午夜av一区| 亚洲一区二三| 清纯唯美亚洲综合一区| 日本亚洲导航| 免费成人av| 日本不卡久久| 九色精品91| 欧美精品二区三区四区免费看视频| 超碰成人在线观看| 国产精品我不卡| 综合久久成人| 成人免费视频网站| 成人福利一区| 国产成人精品福利一区二区三区 | 91超碰这里只有精品国产| 男人天堂视频网| 色8久久人人97超碰香蕉987| 少妇太紧太爽又黄又硬又爽| 欧美日韩亚洲成人| 看片网址国产福利av中文字幕| 午夜视频一区在线观看| 日本高清www免费视频| 欧美激情自拍| 亚洲无限av看| 免费一级在线观看| 亚洲欧洲自拍偷拍| 福利片在线观看| 中文字幕亚洲一区二区三区| 午夜激情在线观看| 麻豆国产精品va在线观看不卡 | 26uuu亚洲伊人春色| 欧美在线极品| 日本伊人精品一区二区三区介绍 | 亚洲精品欧洲| 凹凸国产熟女精品视频| 日韩国产高清影视| 三级一区二区三区| 国产成人精品免费| 97人妻天天摸天天爽天天| 久久久久一区二区三区四区| 亚洲欧美va天堂人熟伦| 成人免费一区二区三区视频| 天天综合天天做| 午夜成人免费电影| 最新中文字幕在线观看视频| 欧美日韩国产一级二级| 亚洲精品免费在线观看视频| 亚洲男人天堂2023| 久久bbxx| 91国内产香蕉| 激情亚洲小说| 国产日本一区二区三区| 九九热精品视频在线观看| 在线观看成人av| 精品福利电影| 国产免费又粗又猛又爽| 国产成人在线看| 久久精品成人av| 中文字幕五月欧美| 日本熟妇一区二区| 欧美日韩久久久| 欧美熟妇另类久久久久久不卡 | 成人免费黄色小视频| 午夜精品爽啪视频| 中文在线免费观看| 亚洲高清一区二| 91在线播放网站| 国内精品中文字幕| 欧美午夜三级| 久久99影院| 欧美激情第8页| 国产精品涩涩涩视频网站| 国产成人啪午夜精品网站男同| 国产小视频自拍| 亚洲午夜视频在线观看| 在线免费看av的网站| 亚洲国产精品成人精品| 高清全集视频免费在线| 日韩av电影在线播放| 国产精伦一区二区三区| 中文字幕中文字幕99| 亚洲欧美卡通另类91av| 亚洲少妇中文字幕| 17c精品麻豆一区二区免费| 黄色av网站免费观看| 精品国产99国产精品| 人人干在线视频| 国产精品久久久久久一区二区 | 日韩在线观看免费| 日韩成人动漫| 精品伦精品一区二区三区视频 | 欧美大片在线看免费观看| 欧美日韩国产网站| 欧美午夜精品久久久久免费视| 狠狠88综合久久久久综合网| 极品粉嫩美女露脸啪啪| 欧美国产综合一区二区| 91在线视频免费播放| 亚洲精品按摩视频| 超免费在线视频| 91视频在线免费观看| 91超碰国产精品| 超碰成人在线播放| 国产精品久久久久久久久免费丝袜 | 免费在线毛片网站| 国产精品免费视频久久久| 精品一区二区三区在线| 99蜜桃臀久久久欧美精品网站| 99热国产精品| 日本三级一区二区| 精品视频在线播放| 超碰超碰人人人人精品| 蜜桃传媒视频麻豆一区| 久久成人国产| 亚洲成人日韩在线| 欧美午夜精品在线| 欧美孕妇性xxxⅹ精品hd| 日本三级久久久| 久久99高清| 韩国中文字幕av| 国产精品青草综合久久久久99| 姑娘第5集在线观看免费好剧| 一区二区三区四区视频| 日本一区免费网站| 一区二区三区四区欧美日韩| 久久精品国产77777蜜臀| 成人精品一二三区| 欧美精品在线一区二区三区| 国产丝袜在线| 成人羞羞视频免费| 国产欧美精品久久| 免费福利视频网站| 欧美乱妇23p| 麻豆视频在线| 成人影片在线播放| 乱码第一页成人| 国产欧美小视频| 日韩视频一区二区三区| 97人人爽人人澡人人精品| 欧美理论一区二区| 久久99久久99| 国产精品第一页在线观看| 亚洲精品视频久久| 黄色成人在线观看网站| 国产一二三区在线播放| 久久婷婷国产综合精品青草| 亚洲精品毛片一区二区三区| 久久久成人av| 久久国产精品免费精品3p| 人人干人人视频| 亚洲精品视频免费看| 四虎精品成人免费网站| 国产美女搞久久| 亚洲精品四区| 日本综合在线观看| 欧美tk丨vk视频| 色成人免费网站| 国产 欧美 日韩 一区| 久久久国产精品不卡| 国产视频在线观看免费| 欧美亚洲日本网站| 97精品国产福利一区二区三区| 无码人妻精品一区二区三| 91福利精品第一导航| 午夜成年人在线免费视频| 日韩wuma| 波多野结衣在线一区| 一区二区三区免费观看视频| 欧美成人在线免费| 精品国产一区二区三区噜噜噜| 精品人妻一区二区三区免费|