摘要:簡要說明長處在于使用模塊規(guī)范,而不是使用的模塊規(guī)范,以及使用的模塊規(guī)范。簡單使用關(guān)于命令行工具使用,請(qǐng)參照官方文檔。相同模塊重復(fù)依賴模塊重復(fù)依賴很容易理解,模塊實(shí)現(xiàn)時(shí)可能分割為多個(gè)子文件實(shí)現(xiàn),每個(gè)子文件內(nèi)部可能會(huì)引用同一個(gè)模塊,如。
簡介
browerify: http://browserify.org/index.html
browserify可以看做瀏覽器端的又一個(gè)模塊化工具,在ES6模塊規(guī)范在前端大規(guī)模落地之前更優(yōu)雅的選擇。
簡要說明browserfify長處在于使用node-flavor模塊規(guī)范,而不是requirejs使用的AMD模塊規(guī)范,以及seajs使用的CMD模塊規(guī)范。打包處理后一般單頁面僅為一個(gè)js文件(當(dāng)然,文件size相當(dāng)可觀)。相對(duì)于其他規(guī)范,最直接的好處是可以直接使用Node生態(tài)中前后端功用模塊,例如uniq, underscore等不依賴Node環(huán)境的包,以及superagent這種做過瀏覽器適配的包。
簡單使用關(guān)于命令行工具使用,請(qǐng)參照官方文檔。在使用中,因?yàn)槭褂?b>webstorm,使用watch的話,每次自動(dòng)保存都會(huì)自動(dòng)觸發(fā),加重系統(tǒng)無謂的負(fù)擔(dān),所以在開發(fā)中,可以選擇直接調(diào)用API的方式,如下使用koa作為簡單的server,部分代碼如下:
javascript"use strict"; var util = require("util"); var through = require("through-gulp"); function streamToPromise(stream) { if (util.isUndefined(stream.pipe)) return Promise.reject("argument is not stream"); return new Promise(function(resolve, reject) { var destiny = new Buffer(""); stream.pipe(through(function(data, encoding, callback) { destiny = Buffer.concat([destiny, data]); callback(); }, function(callback) { resolve(destiny); callback(); })) }); } module.exports = streamToPromise;
此處代碼將stream轉(zhuǎn)換為promise。
javascriptvar transform = require("./promise-stream"); app.use(function *(next) { if (this.path.startsWith("/browserify")) { var bundle = browserify(path.join(__dirname, "static", this.path)).bundle(); bundle = yield transform(bundle); this.type = "application/javascript"; this.body = bundle.toString(); return null; } yield next; });
此處代碼,將browserify文件夾內(nèi)部的js文件,都是用browserify處理,返回處理后的數(shù)據(jù)。如果依賴文件較大的話,時(shí)間會(huì)比較長,視具體環(huán)境而定。
相同模塊重復(fù)依賴模塊重復(fù)依賴很容易理解,模塊實(shí)現(xiàn)時(shí)可能分割為多個(gè)子文件實(shí)現(xiàn),每個(gè)子文件內(nèi)部可能會(huì)引用同一個(gè)模塊,如util。在node環(huán)境下很好理解,在browserify處理后的瀏覽器環(huán)境下,該模塊可以看做是個(gè)單例,不同文件內(nèi)部引用的同名模塊,可以看做引用的同一個(gè)變量,簡單示例所有文件均放置于browserify文件夾下,代碼如下:
javascript// core.js var utils = { "age" : 12 }; utils.increase = function() { this.age += 1; }; module.exports = utils;
javascript// repeat.js var repeat = require("./core"); module.exports = repeat;
javascript// pristine.js var pristine = require("./core"); module.exports = pristine;
javascript// index.js var first = require("./pristine"); var second = require("./repeat"); first.increase(); second.increase(); console.log(first); console.log(second);
瀏覽器執(zhí)行,輸出結(jié)果result.age均為14,和預(yù)想結(jié)果匹配。
Karma集成測試需要用到文件預(yù)處理器,karma-browserify: https://www.npmjs.com/package/karma-browserify。
與karma的AMD模塊測試文件組織結(jié)構(gòu)與引入不同,AMD將測試文件以模塊方式定義,配置中將待測試文件,測試文件設(shè)置為served,然后由單一入口文件加載測試文件。使用browserify作為模塊化工具時(shí),需要顯式引入測試文件,配合karma-browerify使用,示例如下:
javascript// ./browserify/utils.js var uniq = require("uniq"); var utils = {}; utils.uniq = uniq; utils.sum = function(value) { return value.reduce(function(prev, next) { return prev + next; }, 0); }; module.exports = utils;
javascript// ./browserify_test/utils.spec.js var utils = require("../browserify/utils"); describe("browserify style module", function () { it("should uniq array with repeat value", function () { var source = [1, 2, 3, 2, 3, 4]; expect(utils.uniq(source)).toEqual([1, 2, 3, 4]); }); it("should sum array with number value", function () { var source = [1, 2, 3, 4]; expect(utils.sum(source)).toEqual(10); }); });
詳情移步https://github.com/bornkiller/ModuleBoilerplate。
注意如果使用webstorm,會(huì)出現(xiàn)https://github.com/nikku/karma-browserify/issues/23 BUG,修改測試文件,如果不重啟karma server的話,測試文件內(nèi)容不會(huì)改變。
學(xué)習(xí)使用React的過程中,因?yàn)?b>React ES-forward的代碼風(fēng)格,略顯不適應(yīng),所以選擇先學(xué)習(xí)使用browserify工具,然后延續(xù)React學(xué)習(xí)過程。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/85641.html
摘要:然而,這些模板并不限制你自己對(duì)于使用的架構(gòu)組織和選擇類庫。目前可用的模板包括全功能的,包括熱加載,靜態(tài)檢測,單元測試一個(gè)簡易的,以便于快速開始。 最近, 尤大在和人對(duì)噴的時(shí)候,悄然放出了一個(gè)大招,于是為了追趕他的步伐,趕緊試驗(yàn)了下,并且把原文給大家翻譯下。 原文地址:Announcing vue-cli 譯文源地址: Vuejs自己的構(gòu)建工具 先上原文翻譯: 最近有很多大量關(guān)于Reac...
摘要:淘寶鏡像是一個(gè)完整鏡像,你可以用此代替官方版本只讀,同步頻率目前為分鐘一次以保證盡量與官方服務(wù)同步。全功能的,包括熱加載,靜態(tài)檢測,單元測試一個(gè)簡易的,以便于快速開始。 showImg(https://segmentfault.com/img/bVOBkJ?w=900&h=500); 首先 首發(fā)博客: 我的博客 項(xiàng)目源碼: 源碼 項(xiàng)目預(yù)覽: 預(yù)覽 因?yàn)閭€(gè)人的喜好和工作的需要,一直...
摘要:淘寶鏡像是一個(gè)完整鏡像,你可以用此代替官方版本只讀,同步頻率目前為分鐘一次以保證盡量與官方服務(wù)同步。全功能的,包括熱加載,靜態(tài)檢測,單元測試一個(gè)簡易的,以便于快速開始。 showImg(https://segmentfault.com/img/bVOBkJ?w=900&h=500); 首先 首發(fā)博客: 我的博客 項(xiàng)目源碼: 源碼 項(xiàng)目預(yù)覽: 預(yù)覽 因?yàn)閭€(gè)人的喜好和工作的需要,一直...
摘要:淘寶鏡像是一個(gè)完整鏡像,你可以用此代替官方版本只讀,同步頻率目前為分鐘一次以保證盡量與官方服務(wù)同步。全功能的,包括熱加載,靜態(tài)檢測,單元測試一個(gè)簡易的,以便于快速開始。 showImg(https://segmentfault.com/img/bVOBkJ?w=900&h=500); 首先 首發(fā)博客: 我的博客 項(xiàng)目源碼: 源碼 項(xiàng)目預(yù)覽: 預(yù)覽 因?yàn)閭€(gè)人的喜好和工作的需要,一直...
閱讀 2993·2021-10-19 11:46
閱讀 987·2021-08-03 14:03
閱讀 2946·2021-06-11 18:08
閱讀 2915·2019-08-29 13:52
閱讀 2764·2019-08-29 12:49
閱讀 490·2019-08-26 13:56
閱讀 932·2019-08-26 13:41
閱讀 855·2019-08-26 13:35