gpt4 book ai didi

javascript - gulp browserify reactify 任务很慢

转载 作者:可可西里 更新时间:2023-11-01 02:54:36 24 4
gpt4 key购买 nike

我使用 Gulp 作为我的任务运行器并使用 browserify 来捆绑我的 CommonJs 模块。

我注意到运行我的 browserify 任务非常慢,大约需要 2 到 3 秒,而我只有 React 和一些我为开发构建的非常小的组件。

有没有办法加快任务速度,或者我在任务中有什么明显的问题?

gulp.task('browserify', function() {
var bundler = browserify({
entries: ['./main.js'], // Only need initial file
transform: [reactify], // Convert JSX to javascript
debug: true, cache: {}, packageCache: {}, fullPaths: true
});

var watcher = watchify(bundler);

return watcher
.on('update', function () { // On update When any files updates
var updateStart = Date.now();
watcher.bundle()
.pipe(source('bundle.js'))
.pipe(gulp.dest('./'));
console.log('Updated ', (Date.now() - updateStart) + 'ms');
})
.bundle() // Create initial bundle when starting the task
.pipe(source('bundle.js'))
.pipe(gulp.dest('./'));
});

我正在使用 Browserify、Watchify、Reactify 和 Vinyl Source Stream 以及其他一些不相关的模块。

var browserify = require('browserify'),
watchify = require('watchify'),
reactify = require('reactify'),
source = require('vinyl-source-stream');

谢谢

最佳答案

参见 fast browserify builds with watchify .请注意,唯一传递给 browserify 的是主入口点和 watchify 的配置。

转换被添加到 watchify 包装器中。

文章中的代码逐字粘贴

var gulp = require('gulp');
var gutil = require('gulp-util');
var sourcemaps = require('gulp-sourcemaps');
var source = require('vinyl-source-stream');
var buffer = require('vinyl-buffer');
var watchify = require('watchify');
var browserify = require('browserify');

var bundler = watchify(browserify('./src/index.js', watchify.args));
// add any other browserify options or transforms here
bundler.transform('brfs');

gulp.task('js', bundle); // so you can run `gulp js` to build the file
bundler.on('update', bundle); // on any dep update, runs the bundler

function bundle() {
return bundler.bundle()
// log errors if they happen
.on('error', gutil.log.bind(gutil, 'Browserify Error'))
.pipe(source('bundle.js'))
// optional, remove if you dont want sourcemaps
.pipe(buffer())
.pipe(sourcemaps.init({loadMaps: true})) // loads map from browserify file
.pipe(sourcemaps.write('./')) // writes .map file
//
.pipe(gulp.dest('./dist'));
}

关于javascript - gulp browserify reactify 任务很慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28162686/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com