如何使用gulp webpack-stream生成正确的命名文件?

时间:2016-03-18 02:15:30

标签: javascript gulp webpack webpack-dev-server

目前我们正在使用 Webpack 作为我们的模块加载器,而 Gulp 则用于其他所有内容(sass - > css,和开发/生产构建过程)

我想把webpack的东西包装成gulp,所以我要做的就是键入gulp然后启动,监视并运行webpack以及我们设置的其余部分。

所以我找到了webpack-stream并实施了它。

gulp.task('webpack', function() {
    return gulp.src('entry.js')
        .pipe(webpack({
            watch: true,
            module: {
                loaders: [
                    { test: /\.css$/, loader: 'style!css' },
                ],
            },
        }))
        .pipe(gulp.dest('dist/bundle.js'));
});

问题是它为.js文件生成一个随机字符名称,我们如何在我们的应用程序中使用它?

From the github repo

  

上面将src / entry.js编译成资产,其中webpack为dist /,输出文件名为[hash] .js(webpack生成的构建哈希)。

如何重命名这些文件?每次保存编辑时,新的gulp任务也会生成一个新文件:

enter image description here

我无法使用c2212af8f732662acc64.js我需要将它命名为bundle.js或其他正常的东西。

我们的Webpack配置:

var webpack = require('webpack');
var PROD = JSON.parse(process.env.PROD_DEV || '0');
// http://stackoverflow.com/questions/25956937/how-to-build-minified-and-uncompressed-bundle-with-webpack

module.exports = {
    entry: "./entry.js",
    devtool: "source-map",
    output: {
        devtoolLineToLine: true,
        sourceMapFilename: "app/assets/js/bundle.js.map",
        pathinfo: true,
        path: __dirname,
        filename: PROD ? "app/assets/js/bundle.min.js" : "app/assets/js/bundle.js"
    },
    module: {
        loaders: [
            { test: /\.css$/, loader: "style!css" }
        ]
    },
    plugins: PROD ? [
        new webpack.optimize.UglifyJsPlugin({minimize: true})
    ] : []
};

4 个答案:

答案 0 :(得分:9)

Leon Gaban回答了他的webpack.config.js的样子。我没有在评论中回答这个问题,而是在这里提供它,以便更好地格式化。

根据webpack-stream的文档,"您可以使用第一个参数传递webpack选项" ...

所以,我做了以下操作以强制webpack每次都使用相同的输出名称(对我来说,我使用的是bundle.js):

gulp.task('webpack', ['babelify'],
    () => {
        return gulp.src('Scripts/index-app.js')
            .pipe(webpack({output: {filename: 'bundle.js'} }))
            .pipe(debug({ title: 'webpack:' }))
            .pipe(gulp.dest('Scripts/'));

    });

关键是webpack()中的选项,它们是:

{output: {filename: 'bundle.js'} }

答案 1 :(得分:4)

啊我read on a bit further并想出来了:

gulp.task('webpack', function() {
    return gulp.src('entry.js')
    .pipe(webpack( require('./webpack.config.js') ))
    .pipe(gulp.dest('app/assets/js'));
});

^这里我可以传入我的实际webpack.config,它将使用我已经在那里设置的路径。在我的情况下,我刚刚删除了app/assets/js,因为我现在已经改变了这条路径。

然而,仍然没有世俗的想法,为什么我创建的第一个任务,它生成随机哈希文件名?

答案 2 :(得分:3)

根据文档中的建议,您应该在vinyl-named之前使用管道上的webpack-stream包。这样您就可以使用更清晰的Webpack配置。以下是我自己使用的任务定义:

'use strict';

const gulp = require('gulp'),
      named = require('vinyl-named'),
      webpack = require('webpack-stream');

gulp.task('webpack', function () {
  gulp.src(['./src/vendor.js', './src/bootstrap.js', './src/**/*.spec.js'])
      .pipe(named())
      .pipe(webpack({
        module: {
          loaders: [
            {
              test: /\.js$/,
              loader: 'babel',
              query: {
                presets: ['es2015', 'angular2']
              }
            }
          ]
        }
      }))
      .pipe(gulp.dest('./build'))
});

我面对这个任务定义的唯一问题是子文件夹松开了。例如,./src/components/application.spec.js将生成./build/application.spec.js而不是./build/components/application.spec.js

答案 3 :(得分:1)

不是给你的javascript一个固定的文件名,更好的解决方案是使用gulp-inject并将生成的哈希文件名插入到脚本标记中。这意味着您不必担心已编译的javascript上的缓存过期(这就是首先使用哈希文件名的原因)。

const inject = require('gulp-inject');

gulp.task('webpack', function() {
    const index = './src/index.html';
    const scripts = gulp.src('entry.js')
    .pipe(webpack( require('./webpack.config.js') ))
    .pipe(gulp.dest('dist/js'));

    return target
       .pipe(inject(scripts))
       .pipe(gulp.dest('dist/'));
});

当然,您需要src/index.html中的注入部分:

<!DOCTYPE html>
<html>
<head>
  <title>index page</title>
</head>
<body>

  <!-- inject:js -->
  <!-- endinject -->
</body>
</html>