成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

如何在Gulp中提高Browserify的打包速度

hedzr / 1096人閱讀

摘要:使用官方的插件是個比較有效的提高速度方案。另外在這個任務中須要先執(zhí)行一次實例的方法,但這次打包的速度和直接執(zhí)行是一樣的。然后在用戶改動某個關聯(lián)的文件時,都會自動觸發(fā)任務可以看出,這次打包只花費了毫秒,速度提高了很多。

使用Browserify打包js時如果項目變得越來越大,編譯時間就會相應變得越來越長。使用官方的插件watchify是個比較有效的提高速度方案。

提速原理

watchify的用法和gulp的watch方法比較類似,都是監(jiān)控文件的改動來觸發(fā)一些操作。在gulp中我們可以把一個完整的任務拆分成很多個局部任務,然后使用gulp.watch對這些局部任務進行監(jiān)聽,例如:

gulp.task("build-js1", ...);
gulp.task("build-js2", ...);
gulp.task("build-all-js", ["build-js1", "build-js2"]);

gulp.task("watch-js1", function () {
  gulp.watch("./src/models/**/*.js", ["build-js1"]);
});

gulp.task("watch-js2", function () {
  gulp.watch("./src/views/**/*.js", ["build-js2"]);
});

//gulp.task("watch-js", function () {
//  gulp.watch("./src/**/*.js", ["build-all-js"]);
//});

如上例所示,在監(jiān)測不同局部位置的js文件發(fā)生改動后,則只會自動執(zhí)行相應的build-js1或build-js2等局部任務;而如果直接監(jiān)測所有的js文件,就必須每次執(zhí)行build-all-js任務了。

watchify的提速原理和這個思路有點類似,它可以監(jiān)測個別文件的改動,從而觸發(fā)只將需要更新的文件打包。它須要先執(zhí)行一次完整的打包,首次打包的速度和正常速度是一樣的;然后每次用戶改變某個和browserify關聯(lián)的js文件時,會自動執(zhí)行打包,而這次打包的速度卻非??臁?/p> 具體實例

watchify結合gulp的實例如下:

var gulp = require("gulp"),
  browserify = require("browserify"),
  source = require("vinyl-source-stream"),
  buffer = require("vinyl-buffer"),
  watchify = require("watchify"),
  concat = require("gulp-concat"),
  gulpif = require("gulp-if"),
  argv = require("yargs").argv,
  ...;

function getJsLibName() {
  ...
}

//初始化browserify
var b = browserify({
  entries: "./src/base.js"
})
.plugin(...)
.transform(...);

//執(zhí)行打包js
function bundle() {
  var jsLibName = getJsLibName();

  return b.bundle()
    .pipe(source(jsLibName))
    .pipe(buffer())
    .pipe(gulp.dest("./dist/js").on("end", function() {  //打包js后繼續(xù)進行一些后續(xù)操作
      gulp.src(["./vendor/babelHelpers.js", "./dist/js/" + jsLibName])
      .pipe(concat(jsLibName))
      .pipe(gulpif(argv.min, uglify()))
      .pipe(gulp.dest("./dist/js"))
    }));
}

//定義打包js任務
gulp.task("build-all-js", bundle);

//啟動watchify監(jiān)測文件改動
gulp.task("watch-js", function() {
  b.plugin(watchify);  //設置watchify插件
  b.on("update", function(ids) {  //監(jiān)測文件改動
    ids.forEach(function(v) {
      console.log("bundle changed file:" + v);  //記錄改動的文件名
    });

    gulp.start("build-all-js");  //觸發(fā)打包js任務
  });

  return bundle();  //須要先執(zhí)行一次bundle
});

例中可以在gulpfile.js中將browserify的實例定義在全局,這樣在browserify實例的update事件中就可以正常調用到bundle方法了。

定義通常的打包js任務build-all-js,例如需要整個項目打包執(zhí)行它即可。

多帶帶定義監(jiān)測文件改動的任務watch-js,使用gulp啟動這個任務后,就可以啟動watchify的文件改動監(jiān)測功能了。需要為browserify實例注冊update事件,在該事件中觸發(fā)build-all-js任務即可。另外在這個任務中須要先執(zhí)行一次browserify實例的bundle方法,但這次打包的速度和直接執(zhí)行build-all-js是一樣的。

關于watchify的更多細節(jié)大家可以參考官方文檔及這篇文章:Fast browserify builds with watchify

測試打包速度

首先在啟動watch-js任務時,會執(zhí)行首次打包:

本次打包共花費了6.2秒。

然后在用戶改動某個browserify關聯(lián)的js文件時,都會自動觸發(fā)build-all-js任務:

可以看出,這次打包只花費了203毫秒,速度提高了很多。

更多細節(jié)大家可參考實例的源代碼。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/79212.html

相關文章

  • 基于 Gulp + Browserify 構建 ES6 環(huán)境下自動化前端項目

    摘要:本文特此給大家介紹下如何使用配合來構建基于的前端項目。最后,在目錄下會生成最終的項目文件。執(zhí)行單元測試本例中使用進行單元測試。 隨著React、Angular2、Redux等前沿的前端框架越來越流行,使用webpack、gulp等工具構建前端自動化項目也隨之變得越來越重要。鑒于目前業(yè)界普遍更流行使用webpack來構建es6(ECMAScript 2015)前端項目,網上的相關教程也比...

    yuanxin 評論0 收藏0
  • [Laya游戲開發(fā)]小技巧使Laya構建速度提高10倍

    摘要:為何選擇引擎微信小游戲推出之后,很多公司也相應的進入到微信小游戲這個領域,現(xiàn)在市場上的游戲開發(fā)引擎,如都對小游戲有了很好的兼容性。 1. 為何選擇Laya引擎 微信小游戲推出之后,很多公司也相應的進入到微信小游戲這個領域,現(xiàn)在市場上的游戲開發(fā)引擎,如Cocos、Egret、Laya都對小游戲有了很好的兼容性。目前公司技術棧主要是使用Cocos和Laya,經過幾個項目的接觸,考量了引擎在...

    Harpsichord1207 評論0 收藏0
  • 我他喵到底要怎樣才能生產環(huán)境用上 ES6 模塊化?

    摘要:因此,你還是需要各種各樣雜七雜八的工具來轉換你的代碼噢,我可去你媽的吧,這些東西都是干嘛的我就是想用個模塊化,我到底該用啥子本文正旨在列出幾種可用的在生產環(huán)境中放心使用模塊化的方法,希望能幫到諸位后來者這方面的中文資源實在是忒少了。 原文發(fā)表在我的博客上。最近搗鼓了一下 ES6 的模塊化,分享一些經驗 :) Python3 已經發(fā)布了九年了,Python 社區(qū)卻還在用 Python 2...

    KaltZK 評論0 收藏0
  • webpack 3 零基礎入門教程 #1 - 介紹

    摘要:所以它在某些程度上,跟的功能有些相同。嚴格上講,模塊化不是他強調的東西,他旨在規(guī)范前端開發(fā)流程。更是明顯強調模塊化開發(fā),而那些文件壓縮合并預處理等功能,不過是他附帶的功能。 1. webpack 是什么? showImg(https://segmentfault.com/img/remote/1460000012293461); 先來說一下 webpack 是什么。 webpack 的...

    張紅新 評論0 收藏0
  • Javascript模塊化及webpack基本介紹

    摘要:可維護性根據定義,每個模塊都是獨立的。良好設計的模塊會盡量與外部的代碼撇清關系,以便于獨立對其進行改進和維護。這標志模塊化編程正式誕生。的模塊系統(tǒng),就是參照規(guī)范實現(xiàn)的。對象就代表模塊本身。 javascript模塊化及webpack基本介紹 JavaScript 模塊化發(fā)展歷程 什么是模塊化 ? 為什么要做Javascript模塊化? JavaScript 模塊化發(fā)展歷程 什么是模...

    figofuture 評論0 收藏0

發(fā)表評論

0條評論

hedzr

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<