leiyanting

导航

 

 

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'
                        };
 

 

posted on 2021-10-24 07:35  leiyanting  阅读(579)  评论(0)    收藏  举报