2017-07-26 64 views
1

我無法使用webpack構建項目,因爲我總是收到語法錯誤。 此外,當我的朋友在Linux上運行相同的代碼(我在Windows 10上工作時),他沒有得到任何錯誤,一切正常。webpack構建開發時的語法錯誤

這裏是我的WebPack配置

const path = require('path'); 

const autoprefixer = require('autoprefixer'); 
const CopyWebpackPlugin = require('copy-webpack-plugin'); 
const ExtractTextPlugin = require('extract-text-webpack-plugin'); 
const HtmlWebpackPlugin = require('html-webpack-plugin'); 
const WebpackMd5Hash = require('webpack-md5-hash'); 

const CommonsChunkPlugin = require('webpack/lib/optimize/CommonsChunkPlugin'); 
const DefinePlugin = require('webpack/lib/DefinePlugin'); 
const HMRPlugin = require('webpack/lib/HotModuleReplacementPlugin'); 
const LoaderOptionsPlugin = require('webpack/lib/LoaderOptionsPlugin'); 
const NamedModulesPlugin = require('webpack/lib/NamedModulesPlugin'); 
const OccurrenceOrderPlugin = require('webpack/lib/optimize/OccurrenceOrderPlugin'); 
const ProgressPlugin = require('webpack/lib/ProgressPlugin'); 
const UglifyJsPlugin = require('webpack/lib/optimize/UglifyJsPlugin'); 

//========================================================= 
// VARS 
//--------------------------------------------------------- 
const NODE_ENV = process.env.NODE_ENV; 
const DEVELOPMENT = NODE_ENV === 'development'; 
const PRODUCTION = NODE_ENV === 'production'; 

const HOST = process.env.HOST || '127.0.0.1'; 
const PORT = process.env.PORT || '3000'; 

//========================================================= 
// LOADERS 
//--------------------------------------------------------- 
const rules = { 
    js: { 
     test: /\.js$/, 
     exclude: /node_modules/, 
     loader: 'babel-loader', 
    }, 

    json: { 
     test: /\.json$/, 
     loader: 'json-loader', 
    }, 

    css: { 
     test: /\.css$/, 
     loader: ExtractTextPlugin.extract({ 
      fallback: 'style-loader', 
      use: ['css-loader', 'resolve-url-loader', 'postcss-loader'], 
     }), 
    }, 

    scss: { 
     test: /\.scss$/, 
     loader: ExtractTextPlugin.extract({ 
      fallback: 'style-loader', 
      use: ['css-loader', 'resolve-url-loader', 'postcss-loader', 'sass-loader'], 
     }), 
    }, 

    fonts: { 
     test: /\.(eot|svg|ttf|woff|woff2)$/, 
     loader: 'file-loader', 
     query: { 
      name: `[name].[ext]`, 
      publicPath: '/assets/fonts/', 
     } 
    }, 

    images: { 
     test: /\.(svg|png|jpg|jpeg|gif)$/, 
     loader: 'file-loader', 
     query: { 
      limit: 10000, 
      name: `[name].[ext]`, 
      publicPath: '/assets/images/', 
     } 
    } 
}; 

//========================================================= 
// CONFIG 
//--------------------------------------------------------- 
const config = {}; 

config.entry = { 
    polyfills: './src/application/polyfills.js', 
    main: ['./src/application/index.js'], 
}; 

config.output = { 
    filename: 'assets/js/[name].js', 
    path: path.resolve('./dist'), 
    // publicPath: '/', 
}; 

config.resolve = { 
    extensions: ['.js', '.json'], 
    modules: [ 
     path.resolve('./src'), 
     'node_modules', 
    ] 
}; 

config.module = { 
    rules: [ 
     rules.js, 
     rules.css, 
     rules.json, 
     rules.scss, 
     rules.fonts, 
     rules.images, 
    ] 
}; 

config.plugins = [ 
    new LoaderOptionsPlugin({ 
     debug: !PRODUCTION, 
     cache: !PRODUCTION, 
     minimize: PRODUCTION, 
     options: { 
      postcss: [ 
       autoprefixer({ 
        browsers: ['last 3 versions'], 
       }) 
      ], 
      sassLoader: { 
       outputStyle: PRODUCTION ? 'compressed' : 'expanded', 
       precision: 10, 
       sourceComments: false, 
       sourceMap: PRODUCTION, 
      } 
     } 
    }), 
    new DefinePlugin({ 
     'process.env.NODE_ENV': JSON.stringify(NODE_ENV), 
    }), 
    new OccurrenceOrderPlugin(true), 
    new NamedModulesPlugin(), 
    new CommonsChunkPlugin({ 
     name: 'polyfills', 
     chunks: ['polyfills'], 
    }), 
    // This enables tree shaking of the vendors modules 
    new CommonsChunkPlugin({ 
     name: 'vendor', 
     chunks: ['main'], 
     minChunks: module => /node_modules/.test(module.resource), 
    }), 
    new CommonsChunkPlugin({ 
     name: ['polyfills', 'vendor'].reverse(), 
    }), 
    new CopyWebpackPlugin([ 
     { 
      from: './src/assets', 
      to: 'assets', 
      ignore: ['**/*.scss'], 
     } 
    ]), 
    new ExtractTextPlugin({ 
     filename: 'assets/css/[name].css', 
     disable: !PRODUCTION, 
     allChunks: true, 
    }), 
    new HtmlWebpackPlugin({ 
     filename: 'index.html', 
     hash: false, 
     inject: 'body', 
     chunksSortMode: 'dependency', 
     template: './src/index.html', 
    }) 
]; 


//===================================== 
// DEVELOPMENT 
//------------------------------------- 

if (DEVELOPMENT) { 
    config.devtool = 'cheap-module-source-map'; 

    config.entry.main.unshift(
     'react-hot-loader/patch', 
     `webpack-dev-server/client?http://${HOST}:${PORT}`, 
     'webpack/hot/only-dev-server', 
    ); 

    config.plugins.push(
     new HMRPlugin(), 
     new ProgressPlugin(), 
    ); 

    config.devServer = { 
     contentBase: path.resolve(__dirname, 'dist'), 
     historyApiFallback: true, 
     host: HOST, 
     hot: true, 
     port: PORT, 
     stats: { 
      cached: true, 
      cachedAssets: true, 
      children: false, 
      chunks: false, 
      chunkModules: false, 
      colors: true, 
      modules: false, 
      hash: false, 
      reasons: true, 
      timings: true, 
      version: false, 
     } 
    }; 
} 


//===================================== 
// PRODUCTION 
//------------------------------------- 
if (PRODUCTION) { 
    config.devtool = 'hidden-source-map'; 

    config.plugins.push(
     new WebpackMd5Hash(), 
     new UglifyJsPlugin({ 
      comments: false, 
      compress: { 
       unused: true, 
       dead_code: true, 
       screw_ie8: true, 
       warnings: false, 
      }, 
      mangle: { 
       screw_ie8: true, 
      } 
     }) 
    ); 
} 

module.exports = config; 

,這是我的package.json腳本

"scripts": { 
    "test": "jest", 
    "server:dev": "set NODE_ENV='development' && webpack-dev-server --color", 
    "start": "npm run server:dev", 
    "build": "set NODE_ENV='production' && webpack --color" 
    }, 

當我嘗試運行 「故宮開始」,我有這樣的錯誤

C:\Users\vellgreen\Desktop\my_webpack_react\webpack.config.js:184 
     ); 
     ^
SyntaxError: Unexpected token) 

當我把這個評論一切正常。

config.entry.main.unshift(
     'react-hot-loader/patch', 
     `webpack-dev-server/client?http://${HOST}:${PORT}`, 
     'webpack/hot/only-dev-server', 
    ); 

    config.plugins.push(
     new HMRPlugin(), 
     new ProgressPlugin(), 
    ); 

當我運行生產一切代碼也未嘗不可。 我的操作系統是Windows 10,webpack v3.1.0,npm v5.3.0,節點v6.10.3。

有誰知道什麼可能會導致這樣的錯誤?

回答

1

函數中的尾隨逗號是一個相對較新的功能,Node開始在version 8中支持它。你的朋友只是使用支持它的版本(它與操作系統無關)。

config.entry.main.unshift(
    'react-hot-loader/patch', 
    `webpack-dev-server/client?http://${HOST}:${PORT}`, 
    'webpack/hot/only-dev-server', 
//        ^--- remove this comma 
); 

config.plugins.push(
    new HMRPlugin(), 
    new ProgressPlugin(), 
//     ^--- and this comma 
); 
+0

工程!非常感謝你的回答和解釋! –