webpack学习---优化--source-map将打包后代码错误提示显示/隐藏

webpack学习---优化--source-map将打包后代码错误提示显示/隐藏

 

source-map提供源代码到构建后代码映射,编译打包后的代码报错的话会提示错误具体位置,或者隐藏源代码     source-map: 一种 提供源代码到构建后代码映射 技术 (如果构建后代码出错了,通过映射可以追踪源代码错误)
    [inline-|hidden-|eval-][nosources-][cheap-[module-]]source-map
    source-map:外部       错误代码准确信息 和 源代码的错误位置     inline-source-map:内联       只生成一个内联source-map       错误代码准确信息 和 源代码的错误位置     hidden-source-map:外部       错误代码错误原因,但是没有错误位置       不能追踪源代码错误,只能提示到构建后代码的错误位置     eval-source-map:内联       每一个文件都生成对应的source-map,都在eval       错误代码准确信息 和 源代码的错误位置     nosources-source-map:外部       错误代码准确信息, 但是没有任何源代码信息     cheap-source-map:外部       错误代码准确信息 和 源代码的错误位置       只能精确的行     cheap-module-source-map:外部       错误代码准确信息 和 源代码的错误位置       module会将loader的source map加入
    内联 和 外部的区别:1. 外部生成了文件,内联没有 2. 内联构建速度更快
    开发环境:速度快,调试更友好       速度快(eval>inline>cheap>...)         eval-cheap-souce-map         eval-source-map       调试更友好           souce-map         cheap-module-souce-map         cheap-souce-map
      --> eval-source-map  / eval-cheap-module-souce-map
    生产环境:源代码要不要隐藏? 调试要不要更友好       内联会让代码体积变大,所以在生产环境不用内联       nosources-source-map 全部隐藏       hidden-source-map 只隐藏源代码,会提示构建后代码错误信息   --> source-map / cheap-module-souce-map

                        const { resolve } = require('path');


                        module.exports = {
                        entry: ['./src/js/index.js', './src/index.html'],
                        output: {
                            filename: 'js/built.js',
                            path: resolve(__dirname, 'build')
                        },
                        module: {
                            rules: [
                            // loader的配置
                            {
                                // 处理less资源
                                test: /\.less$/,
                                use: ['style-loader', 'css-loader', 'less-loader']
                            },
                            ]
                        },
                        plugins: [

                        ],
                        mode: 'development',
                        devServer: {
                            contentBase: resolve(__dirname, 'build'),
                            compress: true,
                            port: 3000,
                            open: true,
                            hot: true
                        },

                        // 提供源代码到构建后代码映射,编译打包后的代码报错的话会提示错误具体位置,或者隐藏源代码
                        devtool: 'eval-source-map'
                        };
 

 

上一篇:Kafka安装及使用


下一篇:CodeForces - 1253F Cheap Robot (多源Dijkstra+最小生成树)