Vue中SourceMap的使用方法详解

目录

一、概述

二、使用方法

三、生成SourceMap

四、优化

五、结语


一、概述

Vue.js是一套构建用户界面的渐进式框架,通过HTML模板或者直接写render函数可以快速开发单页应用。在开发过程中,很多时候我们需要调试代码,追踪错误。Vue官方提供了SourceMap技术,可以帮助我们在错误提示信息中直接链接到源代码,从而更方便地进行调试。

在打包压缩后的JS代码里,有时很难找到错误发生的位置。SourceMap是一种映射关系文件,其中包含了压缩前和压缩后的代码的位置,这个文件可以帮助我们去定位代码的真实位置。

二、使用方法

在Vue CLI中默认是开启SourceMap的,只需要在webpack的配置文件中将其设置为true即可:

module.exports = {
    //...
    productionSourceMap: true
    //...
}

也可以通过vue.config.js文件中进行配置:

module.exports = {
    productionSourceMap: true
}

在代码打包后,压缩的JS文件会携带SourceMap文件一同发布到服务器。如果你需要禁用它,只需将productionSourceMap设置为false。

三、生成SourceMap

在开发过程中,我们可以在webpack的配置文件中设置devtool选项。这个选项配置webpack如何生成SourceMap。以下是一些选项的示例:

module.exports = {
    devtool: 'source-map'
}

这会生成一个外部的source-map文件,在每个JS文件的末尾添加一个sourceURL注释。这些sourceURL注释指向source-map文件的位置。

module.exports = {
    devtool: 'cheap-source-map'
}

这种配置方式比上面的选项更快,会忽略列信息,只有行信息。它会生成一个外部的source-map文件。只是这个文件生成的时候,只包含每个打包后的模块的第一行。

module.exports = {
    devtool: 'inline-source-map'
}

这种选项生成一个base64-encoded inline sourcemap文件,类似于DataUrl。它不会生成外部的source-map文件。

四、优化

然而,开启SourceMap会导致一些性能问题,开发者可以通过一些优化配置来减轻这些性能问题。webpack提供了内联WebWorker来生成SourceMap,同时可以使用cache-loader来缓存生成的SourceMap。

module.exports = {
    module: {
        rules: [
            {
              test: /\.(js|vue)$/,
              use: 'cache-loader',
              enforce: true
            }
        ]
    },
    devtool: 'cheap-source-map',
    output: {
        pathinfo: false
    },
    optimization: {
        minimize: true,
        minimizer: [
            new TerserPlugin({
                test: /\.js(\?.*)?$/i,
                cache: true,
                sourceMap: true,
                parallel: true,
                terserOptions: {
                    safari10: true,
                    compress: {},
                    mangle: true
                }
            })
        ]
    },
}

五、结语

使用Vue SourceMap可以大大提高开发效率,帮助我们快速定位代码错误。同时,为了避免对性能的影响,需要采取一定的优化措施。

◆ 参考资料 ◆

Vue SourceMap详解 - Python技术站 | 前端生产环境调试工具sourcemap的使用-CSDN博客

vue项目打包优化:缩小体积productionSourceMap设置,使用cdn加速_-CSDN博客

Vue的config配置主要用于全局设置,通过Vue.config进行配置。下面是一些常见的config配置项的详解: 1. productionTip:用于在生产环境是否显示生产模式的提示,默认值为true。当为false时,Vue不会在控制台显示生产模式的提示信息。 2. devtools:用于开启或关闭Vue开发者工具,默认值为true。当为false时,Vue开发者工具将无法使用,可以提高生产环境的性能。 3. errorHandler:用于自定义全局错误处理函数。当Vue组件任意位置抛出错误,都会被该处理函数捕获并处理。 4. warnHandler:用于自定义全局警告处理函数。当Vue组件抛出警告时,都会被该处理函数捕获并处理。 5. ignoredElements:用于配置Vue忽略某些自定义元素。这些元素将被Vue视为原始HTML元素处理,不会被Vue的模板编译处理。 6. keyCodes:用于配置自定义按键别名。可以通过该配置项定义特定按键的别名,方便在组件使用。 7. performance:用于在开发环境开启性能追踪。当为true时,Vue将会在开发模式下进行性能追踪,提供相关的警告信息。 8. productionSourceMap:用于控制生产环境是否生成source map文件,默认值为true。当为true时,生成的source map文件可以用于调试和错误追踪。 除了上述常见的配置项外,Vue的config还包括其余一些高级的配置项,用于全局设置和调整Vue的默认行为。需要注意的是,Vue的config是全局配置,一旦设置后将影响整个应用程序的所有Vue组件。因此,在配置时需要谨慎考虑各个配置项的影响和适用场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

儒雅的烤地瓜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值