亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

用webpack4開發小程序的實現方法

2019-11-19 11:24:06
字體:
來源:轉載
供稿:網友

哈,本人是REACT系開發者,工作中需要不停的折騰webpack,為了順帶學習VUE的開發思想和思路,順理成章的請纓為公司小程序打個框架基礎。前期也去了解了下各個小程序開發框架,大體上是通過轉義的思路來解決小程序和VUE/REACT的模板、邏輯關系,不做展開討論了。只是從本人角度分享通過webpack來構建小程序的開發架構。

通過觀察小程序的原有架構,不難發現其已經是一套比較完善的mvvm架構了(類VUE),融合了VUE及REACT的一些特點(以VUE為主),但卻有一些不足,缺失了前端開發人員常用的npm包的引入,動態樣式的編譯等等提升開發效率的工作環境、模式。因此我想如果通過webpack4來為原有架構做一個有益的補充,這樣原生架構不就很完美了嗎?

思路

對等編譯輸出小程序項目的所有文件(嚴格按照小程序需要的文件及目錄結構輸出)。js/wxs通過babel編譯輸出,wxml/json直接輸出,wxss通過stylus編譯輸出(我們使用stylus開發樣式),順帶使用webpack抽離公共模塊文件common.js,并將runtime運行時抽離作為一個獨立文件。這樣既精簡了代碼,又享用到了webpack為我們帶來的好處。嗯,看上去很簡單嘛,實際上卻是踩了不少的坑!腳上的繭老厚了~~~

webpack module配置

module: { rules: [  {   test: //.(wxml|axml)/, // 為支付寶小程序留了個伏筆,哈哈   use: [    relativeFileLoader(isWechat ? 'wxml' : 'axml'), // 這里使用file-loader簡單封裝了一下    'extract-loader',    'html-loader'   ]  },  {   test: //.(jp(e?)g|png|gif)$/,   use: relativeFileLoader()  },  {   test: //.wxss$/,   include: SRC,   use: relativeFileLoader(),  },  {   test: //.wxs$/,   include: SRC,   exclude: /node_modules/,   use: [    relativeFileLoader(),    {     loader: 'babel-loader',     options: {      babelrc: false,      presets: [       'es2015',        'stage-0'      ]     },    }   ]  },  {   test: //.js$/,   use: {    loader: 'happypack/loader',    options: {     id: 'babel'    }   },   exclude: /node_modules/,  },  {   test: //.styl$/,   include: SRC,   use: [    relativeFileLoader(isWechat ? 'wxss' : 'acss'),    'stylus-loader'   ]  } ]},

熟悉webpack的同學通過上面的moudle配置應該能夠看出資源文件編譯的思路,當然直接這樣配置肯定做不到正確編譯,還有一些坑需要踩

全文件entry

為了對等輸出,我們需要把所有文件整理為entry給webpack處理,這樣的好處是js能夠使用npm包,所有文件都能夠支持熱更新機制(webpack的熱更新響應非??欤琯ulp的熱更新很難精細控制,當項目足夠大的時候,響應很慢)

function entries(dir) { var jsFiles = {} let _partten = /[//|//][_](/w)+/; let re_common = /(.*)//common/// const accessExts = ['.wxml', '.wxss', '.styl', '.wxs', '.json', '.png', '.jpg', '.jpeg', '.gif'] if (fse.existsSync(dir)) {  globby.sync([`${dir}/**/*`, `!${dir}/js/**/cloudfunctions`, '!node_modules', `!${dir}/dist`]).forEach(function (item) {   if (!re_common.test(item)) {    if (!_partten.test(item)) {     const fileObj = path.parse(item)     const xcxSrc = path.join(dir, 'js')     if (~item.indexOf(xcxSrc)) {      const fileStat = fs.statSync(item)      const relativeFile = item.replace(xcxSrc, '')      let relativeKey = relativeFile.replace(fileObj.ext, '').substring(1)      if (fileObj.ext == '.js') {       jsFiles[relativeKey] = item      }      else {       if (accessExts.indexOf(fileObj.ext) > -1) {        jsFiles['nobuild__' + relativeFile] = item       }      }     }    }   }  }) } return jsFiles}

上述是entry的生成代碼,涵蓋了小程序目錄結構下的所有需要的文件,并加上了一些特定的標識,以便于后續文件編譯輸出

非JS文件的輸出

在entry方法中我們將wxml,wxss等文件作為entry統統灌給webpack去處理,正常我們使用webpack時是不會把非js文件作為entry輸給webpack的。你猜webpack會報錯嗎,----- 哈哈,報錯就講不下去了,webpack會傻傻的把每個entry文件都當做js來對待,并且正常輸出,*.wxml.js,等等,這是什么鬼,我并不需要這樣的東東。加個插件來處理一下

compiler.hooks.compilation.tap('wpConcatFile', (compilation, params) => { compilation.hooks.beforeChunkAssets.tap('wpConcatFile', () => {  compilation.chunks = compilation.chunks.filter(function (item) {   return item.name.indexOf('nobuild__') == -1  }) }) ... ...}

nobuild__是在生成entry代碼是給非js文件加上的prefix前綴,在插件中我們排除掉非js,將正常的js文件重新chunk,js文件就能夠正常的輸出了,那么那些非js文件呢?webpack并不會編譯生成它們,中途它們就會被module中的xx-loader處理完,然后被file-loader給甩出去了。

全局變量替換

將全局變量替換為微信小程序的wx,我們通過插件解決

const globalVar = 'wx'.........let contentObj = compilation.assets[file]let code = contentObj.source()code = code.replace(windowRegExp, that.globalVar);contentObj = new RawSource(code)compilation.assets[file] = new ConcatSource( contentSource, '/n', '//**auto import common&runtime js**//', '/n', contentObj,);

通過上述代碼不難看出,我們讀取了每個文件的源碼,并將全局變量window/global替換為wx,再進行源碼重組。

運行時文件引入

我們需要引入runtime.js和common.js文件,runtime運行環境是webpack為每個編譯文件插入的用于解析define, require, module等等這些的文件引入方法,為了精簡文件,我們將之抽離為runtime.js,common.js為我們抽離出來的公共模塊文件。在web/h5下引入這些資源是不是so easy,但你還記得我們是在小程序環境下嘛,并不能通過<script>標簽來引入資源文件啊啊啊,你會不會猛拍腦門,一下就慌了(哈哈)。老辦法,我們通過插件解決

const lens = []let posixPath = ''const matchIt = chunk.name.match(////g)if (matchIt) { matchIt.forEach(it => lens.push(this.prePath)) // posixPath = './'+lens.join('') posixPath = lens.join('')} else { posixPath = './'}let posixPathFile = posixPath + 'runtime.js'let contentSource = this.contentSource.replace('~~~~', posixPathFile)if (chunk.name.indexOf('runtime') > -1) { posixPathFile = posixPath + 'common.js' if (hasCommon) {  contentSource = this.contentSource.replace('~~~~', posixPathFile) } else {  contentSource = '' }}

上述代碼片段中,posixPath是我們通過一個小的算法來推算資源引入的路徑深度變量,輸出并重寫源文件chunk,這樣我們就解決了資源引入的問題

webpack-dev-server

引入webpack-dev-server能夠使得webpack的編譯能夠簡單的輸出到硬盤上,webpack默認是內存文件系統,并不輸出(當然有其他方法,比如再寫個插件或更換文件系統啥的),除了文件輸出,webpack-dev-server還能夠為我們提供mock數據服務,呵呵~,這里不展開了,大家有興趣百度一下,還能夠為我們訪問后臺接口作proxy,這里也不展開了。

通過上述操作,我們就能得到小程序結構的對等輸出,剩下我們只需要將輸出文件導入到小程序編輯器中,接下來就是開發工作了。嗯,這樣就可以開始給小程序搬磚了,開心嗎?

如果你想參考一下我們的編譯代碼,可以看這里 https://github.com/webkixi/aotoo-hub/blob/master/build/webpack.xcx.config.js

如果你想了解下我們的架構,可以看這里  https://github.com/webkixi/aotoo-hub

如果你想使用我們的架構,怕不怕?怕的話,你看著辦吧,哈哈! 不怕看這里 https://www.npmjs.com/package/aotoo-cli

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产女人18毛片水18精品| 中文字幕国产亚洲2019| 日韩av在线天堂网| 久久手机精品视频| 久久精品91久久香蕉加勒比| 日本午夜精品理论片a级appf发布| 亚洲国产成人爱av在线播放| 2020欧美日韩在线视频| 另类视频在线观看| 亚洲视频电影图片偷拍一区| 欧美精品久久久久久久久| 91高潮在线观看| 久久视频在线直播| 久久精品中文字幕电影| 欧美激情一区二区久久久| 久热国产精品视频| 7m精品福利视频导航| 91精品国产91久久久久久久久| 日韩av在线影视| 国产精品美女久久久免费| 欧美视频专区一二在线观看| 日本亚洲欧洲色| 岛国av一区二区| 国产一区二区三区在线观看网站| 色婷婷综合久久久久中文字幕1| 亚洲午夜国产成人av电影男同| 亚洲专区在线视频| 久久精品国产久精国产思思| 亚洲自拍偷拍在线| 亲子乱一区二区三区电影| 日产精品久久久一区二区福利| 亚洲男人的天堂在线| 国产丝袜视频一区| 欧美日韩精品国产| 国产日韩在线播放| 亚洲视频一区二区三区| 国产福利精品在线| 日韩av在线网页| 国产91精品网站| 福利视频导航一区| 在线观看精品自拍私拍| 日韩av在线天堂网| 亚洲高清久久久久久| 欧美夫妻性生活视频| 欧美亚洲另类视频| 国产精品视频网站| 久久夜精品va视频免费观看| 午夜剧场成人观在线视频免费观看| 成人福利在线观看| 国产一区视频在线播放| 日韩中文字幕在线观看| 亚洲片国产一区一级在线观看| 日韩av中文字幕在线| 美乳少妇欧美精品| 欧美视频一二三| 91社影院在线观看| 亚洲第一视频在线观看| 亚洲成人免费在线视频| 亚洲综合一区二区不卡| 亚洲视频一区二区三区| zzjj国产精品一区二区| 国产香蕉一区二区三区在线视频| 一区二区三区 在线观看视| 欧美中文在线免费| 成人精品久久一区二区三区| 国产日韩专区在线| 国产中文欧美精品| 日韩精品在线观| 美女视频黄免费的亚洲男人天堂| 精品国产乱码久久久久久婷婷| 国产成人精品一区二区| 欧美日韩免费观看中文| 国产欧美日韩视频| 国产91ⅴ在线精品免费观看| 伦伦影院午夜日韩欧美限制| 成人妇女免费播放久久久| 黑人狂躁日本妞一区二区三区| 久久久精品欧美| 国产精品ⅴa在线观看h| 91免费精品国偷自产在线| 成人国产精品免费视频| 国产精品欧美日韩| 欧美一二三视频| 欧美亚洲第一区| 秋霞成人午夜鲁丝一区二区三区| 伊人久久久久久久久久久久久| 菠萝蜜影院一区二区免费| 亚洲国产毛片完整版| 欧美日韩精品在线| 亚洲激情自拍图| 亚洲肉体裸体xxxx137| 91地址最新发布| 日韩欧美一区二区三区久久| 亚洲国产精品人人爽夜夜爽| 亚洲国产一区自拍| 亚洲国产精品va在线看黑人动漫| 国产欧美日韩中文字幕| 日韩激情在线视频| 色无极亚洲影院| 久久影视电视剧免费网站清宫辞电视| 欧美中文字幕在线播放| 亚洲精品电影久久久| 91视频免费在线| 成人性生交大片免费看视频直播| 久热精品视频在线观看一区| 国产精品678| 久久久久北条麻妃免费看| 国产精品一区二区三区免费视频| 日韩在线一区二区三区免费视频| 在线看欧美日韩| 亚洲电影免费观看高清完整版| 精品久久中文字幕久久av| 欧美中文字幕视频| 欧美日韩加勒比精品一区| 96sao精品视频在线观看| 国产精品jvid在线观看蜜臀| 日韩天堂在线视频| 亚洲天堂男人的天堂| 国产精品h片在线播放| 中文字幕日韩视频| 疯狂做受xxxx高潮欧美日本| 国产精品免费久久久久影院| 日本久久亚洲电影| 亚洲第一男人av| 日韩中文在线视频| 亚洲最大av网| 国产精品视频不卡| 国产精品久久久久久久久久久不卡| 欧美xxxx14xxxxx性爽| 亚洲色图欧美制服丝袜另类第一页| 亚洲国产天堂久久国产91| 久久成人18免费网站| 日韩欧美高清视频| 91在线视频精品| 性欧美长视频免费观看不卡| 欧美在线视频一二三| 日韩在线视频观看正片免费网站| 久久夜色撩人精品| 日韩精品免费观看| 久久影院中文字幕| 一区二区亚洲精品国产| 欧美性xxxx极品hd满灌| 国自产精品手机在线观看视频| 欧美午夜视频在线观看| 久久精品99久久香蕉国产色戒| 国产91免费看片| 国产精品1区2区在线观看| www.欧美精品| 日韩成人中文字幕| 国产精品草莓在线免费观看| 永久免费毛片在线播放不卡| 国产精品高清网站| 日韩av综合网站| 日韩大陆欧美高清视频区| 国产精品流白浆视频| 国内精品久久影院| 亚洲第一福利网站| 亚洲va码欧洲m码| 国产精品扒开腿做爽爽爽男男| 国内揄拍国内精品少妇国语| 亚洲精品aⅴ中文字幕乱码| 日韩中文在线观看| 欧美丝袜第一区| 亚洲精品成人免费|