使用vue打包时vendor文件过大或者是app.js文件很大的问题

处理vue打包时vendor文件过大或者是app.js文件很大的问题可以通过以下方法进行:

1. 使用动态导入 (Dynamic Import)

动态导入是Vue.js 2.6版本开始提供的一个特性,可以让你在运行时(runtime)条件下去组织代码切割,从而减小打包体积。它是通过 import() 语法实现的。使用动态导入可以减少app.js的大小,提高页面加载速度。

以vue-router为例,在路由的时候使用动态导入:

const router = new VueRouter({
  routes: [
    {
      path: '/about',
      name: 'about',
      component: () => import(/* webpackChunkName: "about" */ './views/About.vue')
    },
    ...
  ]
})

其中,webpackChunkName可以指定代码块的名称。指定了chunk名称后,可以在webpack输出的文件中查看到这个代码块的文件名。

2. 使用分包(splitChunks)

在Webpack4中,splitChunks已经成为了一个新的option,在optimization中使用。可以把第三方库和模块代码分别打包到少数的几个文件中。

在vue.config.js中配置:

module.exports = {
  configureWebpack: {
    optimization: {
      splitChunks: {
        chunks: 'async',
        minSize: 30000,
        maxSize: 0,
        minChunks: 1,
        maxAsyncRequests: 5,
        maxInitialRequests: 3,
        automaticNameDelimiter: '~',
        name: true,
        cacheGroups: {
          vendors: {
            test: /[\\/]node_modules[\\/]/,
            priority: -10
          },
          default: {
            minChunks: 2,
            priority: -20,
            reuseExistingChunk: true
          }
        }
      }
    }
  }
}

其中,test: /[\/]node_modules[\/]/ 表示只打包来自 node_modules 文件夹下的模块,而 common 文件夹下的模块则不打包。

使用该方法,webpack会将node_modules中的第三方库抽取成vendor.js,这样就可以减少vendor.js的文件大小,从而加快网页的加载速度。

以上就是使用vue打包时处理vendor文件过大或者是app.js文件很大的问题的攻略。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:使用vue打包时vendor文件过大或者是app.js文件很大的问题 - Python技术站

(0)
上一篇 2023年5月28日
下一篇 2023年5月28日

相关文章

  • Vue编写可显示周和月模式的日历 Vue自定义日历内容的显示

    下面是关于“Vue编写可显示周和月模式的日历 Vue自定义日历内容的显示”的完整攻略: 1. 确定需求和设计方案 在编写Vue日历组件之前,我们需要先确认我们的需求和设计方案。首先,我们需要支持周模式和月模式的日历显示,同时还需要支持自定义日历内容的显示。为了实现这些需求,我们可以考虑使用如下设计方案: 使用Vue.js框架编写日历组件,使用组件的方式实现周…

    Vue 2023年5月29日
    00
  • vue跨域问题:Access to XMLHttpRequest at‘httplocalhost解决

    跨域问题指的是在同源策略下,浏览器禁止向不同源地址发送请求,这是为了保证客户端数据的安全性。而Vue.js作为常用的前端框架,在与后台服务进行交互时,就需要面对跨域问题。 下面,我们就来详细讲解一下“Vue跨域问题:Access to XMLHttpRequest at ‘http://localhost’解决”的完整攻略。 什么是跨域问题 跨域问题是浏览器…

    Vue 2023年5月27日
    00
  • 改变vue请求过来的数据中的某一项值的方法(详解)

    下面我将详细讲解改变 Vue 组件请求过来的数据中的某一项值的方法。 确定需要修改的数据 首先我们需要确定需要修改的数据,可以通过在 Vue 组件的 mounted 或 created 钩子中打印请求到的数据,查看需要修改的数据具体位置。比如下面这个例子: export default { data() { return { user: null } }, …

    Vue 2023年5月29日
    00
  • Vue打包后访问静态资源路径问题

    Vue是一种流行的JavaScript框架,用于构建交互式的现代Web应用程序。Vue的打包可以将应用程序的所有资源(例如HTML,JavaScript,CSS和图像)打包成几个文件,使应用程序易于部署。但是,Vue打包后,用户在访问应用程序时可能会遇到静态资源路径问题。为解决这一问题,我们可以采用以下攻略: 问题描述 Vue打包后,由于路径设置不正确,可能…

    Vue 2023年5月28日
    00
  • 分享Vue组件传值的几种常用方式(一)

    下面我会详细讲解“分享Vue组件传值的几种常用方式(一)”的完整攻略。 标题分析 标题:“分享Vue组件传值的几种常用方式(一)” 分析:该标题属于文档类文章,主要内容是针对Vue组件传值方面的一些常用方式进行介绍。 文章结构 引言:介绍Vue组件传值的重要性和文章将要介绍的内容。 父组件向子组件传值的方式: props属性 和 \$emit方法 对prop…

    Vue 2023年5月27日
    00
  • npm install安装报错的几种常见情况

    以下是关于npm install安装报错的几种常见情况的攻略。 1. 版本兼容问题 当我们使用 npm install 安装依赖时,npm 会尝试找到最新或符合版本约束的依赖版本,并自动安装。但是,有时候我们会遇到版本兼容问题而导致安装报错。比如: ERROR: Failed to download Chromium r818858! Set "P…

    Vue 2023年5月28日
    00
  • 详解vue-cli 脚手架项目-package.json

    下面是详解vue-cli 脚手架项目-package.json的完整攻略。 什么是vue-cli脚手架项目-package.json 在使用Vue.js构建前端项目时,我们通常使用Vue CLI来快速创建项目的基础结构。Vue CLI通过自动生成基础代码、提供开发服务器、打包和部署等功能,减少了我们在项目搭建和管理过程中的工作量。在Vue CLI生成的项目中…

    Vue 2023年5月28日
    00
  • 解决vue init webpack 下载依赖卡住不动的问题

    当使用vue-cli的模板生成器vue init webpack脚手架时,有时在安装依赖包的时候会卡在某个包上不动,导致整个过程无法继续。这种情况可能是由于网络问题、依赖版本冲突等多种原因造成的,以至于我们无法轻易判断出原因。但是,我们可以有一些解决办法来尝试解决这个问题。 下面是解决vue init webpack下载依赖卡住不动的问题的完整攻略: 1.更…

    Vue 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部