如何启用源地图?我这样做:
var browserify = require("gulp-browserify")
gulp.task("compile:client", function() {
gulp.src("src/client/app.coffee", {
read: false
})
.pipe(browserify({
debug: true // THIS DOES NOTHING :(
transform: ['coffeeify'],
extensions: ['.coffee']
}))
.pipe(rename('app.js'));
});
哎呀...出于某种原因,github page对于gulp-browserify,它说: 插件是黑色的。
我不明白......我觉得如何使用浏览器和我的coffeescript文件呢?
UPD:哈!我错了:debug
选项有效。它只是将源地图信息粘贴到输出javascript文件中。真棒。问题仍然悬而未决:为什么这个插件被列入黑名单?
答案 0 :(得分:10)
我通过抓取网络找到了解决方案,它看起来像这样:
var browserify = require('browserify');
var gulp = require('gulp');
var exorcist = require('exorcist');
var source = require('vinyl-source-stream');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var sourcemaps = require('gulp-sourcemaps'); // https://www.npmjs.org/package/gulp-sourcemaps
gulp.task('browserify', function(){
return browserify({
entries: ['./file1.js'],
debug: true
})
.bundle()
.pipe(exorcist('./output.js.map'))
.pipe(source('output.js'))
.pipe(gulp.dest('./'));
});
gulp.task('together', ['browserify'], function() {
return gulp.src('output.js')
.pipe(sourcemaps.init({loadMaps: true}))
.pipe(concat('all-with-maps.js'))
.pipe(uglify())
.pipe(sourcemaps.write('.', {addComment: true /* the default */, sourceRoot: '/src'}))
.pipe(gulp.dest('dist'));
});
确保您安装了最新版本的browserify(我今天使用的是5.10.0)..您曾经需要将{debug: true}
传递给bundle()
来电..但它已移动直接到browserify()
。
关于黑名单:我们认为最好直接使用browserify()
,就像我们在这里一样。它似乎不需要插件。
答案 1 :(得分:3)
请看一下:
https://github.com/gulpjs/plugins/issues/47
在这里:
https://github.com/gulpjs/gulp/issues/369
更新:
我不认为下面的内容是“凌乱”。
var source = require('vinyl-source-stream');
var browserify = require('browserify');
var bundler = browserify('./js/index.js');
gulp.task('compile', function(){
return bundler.bundle({standalone: 'noscope'})
.pipe(source('noscope.js'))
.pipe(gulp.dest('./dist'));
});