解决 vue热加载编译速度慢问题,引入按需加载插件 dynamic-import-node

21 篇文章 0 订阅
遇到问题

当编译项目时,需要花费很长时间,会在67%左右卡顿

解决办法

1、安装 babel-plugin-dynamic-import-node

npm install babel-plugin-dynamic-import-node

2、
vue-cli3:修改babel.config.js文件 (vue-cli3)
vue-cli2:.babelrc文件里添加配置dynamic-import-node

module.exports = {
    presets: [
        '@vue/cli-plugin-babel/preset'
    ],
    'env': {
        'development': {
          'plugins': ['dynamic-import-node']
        }
    }
}
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
> 为什么我们要按 Vue 组件?使用 Vue Router 的 `component` 配置项的值为什么可以是一个函数?其具体实现方式是什么? 当我们的项目变得越来越大时,页面也逐渐增多,如果一开始便将所有组件都进来,那么页面会变得过于庞大,进而导致启动时间变长,用户体验也会受到影响。因此,我们希望只有在用户真正要使用某个组件时才它,这就是按组件的主要目的。 Vue Router 提供了 `component` 配置项用于指定当前路由所渲染的组件,它支持两种类型的值:组件对象和组件构造器(即通过 `Vue.extend(options)` 创建的组件),但它也可以是一个函数。这是因为 Vue Router 允许我们使用异步组件,而异步组件是通过函数形式来定义的。具体实现方式如下: ```javascript { path: '/async-component', component: () => import('./components/AsyncComponent.vue') } ``` 上述代码中,`AsyncComponent.vue` 是异步组件,它使用了 Webpack 提供的 `import()` 函数来懒组件,这个函数会异步代码块并且返回一个 Promise,Promise resolve 的值就是组件本身。在路由跳转时,如果当前组件尚未被,则会触发异步,直到组件被完整编译后才会被渲染到页面上。 按组件是一种非常常见也非常实用的优化方式,它不仅可以缩短页面时间,也可以降低首次渲染的复杂度,提升用户的使用体验。同时,在实际开发中,我们也要考虑代码分割的问题,将代码分成多个较小的块,按。这样不仅可以减小网页的大小,同时也是打包优化的一部分。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值