react项目下webpack版本更新导致的配置报错解决方案

前端之家收集整理的这篇文章主要介绍了react项目下webpack版本更新导致的配置报错解决方案前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

webpack1.x项目配置,在更新webpack版本时出现的问题解决

问题一:

resolve:{
    // 引入文件不写后缀名配置
    extensions:['','.js','.jsx']
}

配置时 extensions 第一个参数不能是空,改为 extensions:['.js','.jsx']

问题二:

配置postcss有误,webpack2.0以上不再允许配置自定义属性,需要再plugin中定义
修改

postcss: [
        require('autoprefixer') //调用autoprefixer插件,例如 display: flex
]

修改
在 plugin中新增

new webpack.LoaderOptionsPlugin({
  options: {
    postcss: function () {
      return [autoprefixer];
    }
  }
})

问题三:

webpack-dev-server配置不再有colors属性

devServer: {
        // colors: true,//终端中输出结果为彩色
        historyApiFallback: true,//不跳转,在开发单页应用时非常有用,它依赖于HTML5 history API,如果设置为true,所有的跳转将指向index.html
        inline: true,//实时刷新
        hot: true  // 使用热加载插件 HotModuleReplacementPlugin
    }

问题四:


使用加载器时不再允许 省略‘-loader’后缀
修改前:

module: {
        loaders: [
            { test: /\.(js|jsx)$/,exclude: /node_modules/,loader: 'babel' },{ test: /\.less$/,loader: 'style!css!postcss!less' },{ test: /\.css$/,loader: 'style!css!postcss' },{ test: /\.(png|gif|jpg|jpeg|bmp)$/i,loader:'url-loader?limit=5000' },// 限制大小5kb
            { test: /\.(png|woff|woff2|svg|ttf|eot)($|\?)/i,loader:'url-loader?limit=5000'} // 限制大小小于5k
        ]
    }

修改后:

module: {
        loaders: [
            { test: /\.(js|jsx)$/,loader: 'babel-loader' },loader: 'style-loader!css-loader!postcss-loader!less-loader' },loader: 'style-loader!css-loader!postcss-loader' },loader:'url-loader?limit=5000'} // 限制大小小于5k
        ]
    }

问题五:


postcss配置有误,更换引入的方式,创建postcss.config.js文件添加代码如下:

var autoprefixer = require('autoprefixer');
module.exports = {
  plugins: {
    'autoprefixer': {browsers: 'last 5 version'}
  }
}

在webpack2.6版本 可以通过直接在webpack.config.js中添加如下代码使用:

plugins: [  
        new webpack.LoaderOptionsPlugin({  
            options: {  
                postcss: function(){  
                    return [  
                        require("autoprefixer")({  
                            browsers: ['ie>=8','>1% in CN']  
                        })  
                    ]  
                }  
            }  
        })  
]

至此,更新了webpack以后执行npm start(看自己配置是怎样的,package.json的scripts配置),应该就可以跑起来了,有什么不对的地方,望指教。

猜你在找的React相关文章