webpack不能把打包的文件输出到绝对路径吗?

图片描述

一直卡在这里...

const webpack = require('webpack');
const UglifyJSPlugin = require("uglifyjs-webpack-plugin");
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin');

module.exports = {
  entry: "./src/main.js",
  output: {
    filename: "D:/workspace/aa/WebContent/static/bb/js/build.js"
  },
  module: {
      loaders : [
          {
              test : /\.scss$/,
              loader : ExtractTextPlugin.extract({
                    use:[
                      {
                        loader: 'css-loader'
                      },
                      {
                        loader:'sass-loader'
                      }
                    ]
              })
          }
      ]


  },
  resolve: {
    extensions: [ '.js', '.jsx']
  },
  plugins: [new webpack.BannerPlugin("xxx.com"),new UglifyJSPlugin(),new OptimizeCSSPlugin(),new ExtractTextPlugin("D:/workspace/aa/WebContent/static/bb/css/style.css")]
};

我改了filename的路径和ExtractTextPlugin的样式路径..
以下是正常的

const webpack = require('webpack');
const UglifyJSPlugin = require("uglifyjs-webpack-plugin");
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin');

module.exports = {
  entry: "./src/main.js",
  output: {
    filename: "build/build.js"
  },
  module: {
      loaders : [
          {
              test : /\.scss$/,
              loader : ExtractTextPlugin.extract({
                    use:[
                      {
                        loader: 'css-loader'
                      },
                      {
                        loader:'sass-loader'
                      }
                    ]
              })
          }
      ]


  },
  resolve: {
    extensions: [ '.js', '.jsx']
  },
  plugins: [new webpack.BannerPlugin("xxx.com"),new UglifyJSPlugin(),new OptimizeCSSPlugin(),new ExtractTextPlugin("build/style.css")]
};

这样就可以打包成功

D:/workspace/aa/WebContent 是我的eclipse的项目路径

因为我用eclipse开发java项目,我不想每次修改静态样式 ,js文件后,手动把打包好的文件,又覆盖到eclipse项目的WebContent里.有什么办法吗?

阅读 4.8k
2 个回答

可以用 node 中的path对象,path.join(__dirname, '..', dir)dir相对于当前路径

https://segmentfault.com/a/11...
参考下吧 骚年 !! 很奇怪你上面的配置的用意 . 一般都是打包到当前目录的某个文件夹下面. 你这个居然是其他目录,而且还是单个js文件. 就是你要打包到一起, 你最好也用require.

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏