前端vue项目加快热更新——提高部署速度——采用babel-plugin-dynamic-import-node插件

本文主要是介绍前端vue项目加快热更新——提高部署速度——采用babel-plugin-dynamic-import-node插件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

vue热更新编译慢的解决办法

  • 安装插件:babel-plugin-dynamic-import-node
  • yarn add babel-plugin-dynamic-import-node -D

增加配置文件:babel.config.js

module.exports = {env: {development: {plugins: ['dynamic-import-node']}}
}

babel-plugin-dynamic-import-node作用

babel-plugin-dynamic-import-node是一个Babel插件,它的作用是将JavaScript中的动态导入(dynamic import)语句转换为对Node.jsrequire函数的调用。

动态导入是JavaScript中一种异步加载模块的方式,它允许在运行时加载和执行模块。动态导入语法为:

import('/path/to/module').then(module => {// 这里是模块加载成功后执行的代码}).catch(error => {// 这里是模块加载失败后执行的代码});

但是,动态导入在Node.js中并没有得到原生支持,因此如果要在Node.js环境中使用动态导入,就需要使用babel-plugin-dynamic-import-node这个插件将其转换为Node.js可以识别的require函数调用。这样就可以在Node.js中使用动态导入的语法了。

例如,如果有一个JavaScript文件,其中使用了动态导入语法,但是你想在Node.js中执行这个文件,那么你可以使用Babel将这个文件转换为Node.js可以执行的代码,并在转换时使用babel-plugin-dynamic-import-node插件,从而使得动态导入语法在Node.js中得到支持。
也就是说,安装的插件babel-plugin-dynamic-import-node,与import路由加载方式配套使用才能发挥期作用。

问题原因

在开发vue项目中,一般组件路采取会异步加载,动态导入的方式,就是咋们说的懒加载导致的热更新比较慢
首先 路由懒加载有两种写法
第一种: () => import()
第二种: resolve => [ require(), resolve ]
两种方法都实现了路由的异步加载. 也就导致了热更新慢.
解决办法就是 使用dynamic-import-node插件. 这个插件是将所有import替换成同步的require.
!! 注意: 是同步的require


配置vue.config.js

HotModuleReplacement是什么?

  • 在开发时,我们修改其中一个模块代码,Webpack默认会将所有模块重新打包编译,速度很慢。
    我们需要做到修改某个模块代码,就只有这个模块代码重新打包编译,其他模块不变,这样速度就会有很大的提升。
    如果我们是webpack5构建的项目,则会有更多的发挥空间!

HotModuleReplacement(HMR/热模块替换):在程序运行中,替换、添加或删除模块,而无需重新加载整个页面

//开发服务器
devServer: {host: '127.0.0.1', // 域名port: '3000', // 端口open: true, // 是否自动打开浏览器hot: true,// 开启HMR功能(只能用于开发环境,生产环境不需要)
},

知识点:

vue.config.js 文件中的 devServer 选项是用来配置 Vue.js 应用程序开发服务器的,它支持传递一个对象,该对象具有以下属性:

  • host:字符串类型,指定开发服务器监听的主机名,默认值为 ‘localhost’。

  • port:数字类型,指定开发服务器监听的端口号,默认值为 8080。

  • https:布尔类型,指定是否使用 HTTPS 协议,默认为 false。

  • proxy:对象类型,用于配置开发服务器的代理选项,它可以是一个字符串或者一个对象。如果是一个字符串,则表示代理的目标 URL;如果是一个对象,则可以指定以下属性:

    • target:字符串类型,表示要代理的目标 URL。

    • changeOrigin:布尔类型,表示是否改变代理请求头中的 ‘Origin’ 字段,默认为 false。

    • pathRewrite:对象类型,用于指定要重写的路径规则。

  • open:布尔类型,表示是否在启动开发服务器时自动打开浏览器,默认为 false。

  • overlay:布尔类型,表示是否在浏览器中显示编译器错误和警告,默认为 true。

  • hotOnly:布尔类型,表示是否禁用热更新,如果设置为 true,则只使用热替换(HMR)而不进行整个页面重载,默认为 false。

  • disableHostCheck:布尔类型,表示是否禁用开发服务器的 host 检查,默认为 false。

  • headers:对象类型,表示设置 HTTP 响应头部信息的选项。

  • Cache-Control:字符串类型,用于控制 HTTP 缓存的响应头部信息。

  • X-Frame-Options:字符串类型,用于设置防止跨域攻击的 X-Frame-Options 响应头部信息。

  • X-XSS-Protection:字符串类型,用于设置防止跨站脚本攻击的 X-XSS-Protection 响应头部信息。

以上是 devServer 中可用的一些常用选项,如果您需要了解更多配置选项,可以参考 Vue.js 官方文档:cli.vuejs.org/config/#dev…

这篇关于前端vue项目加快热更新——提高部署速度——采用babel-plugin-dynamic-import-node插件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/939025

相关文章

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h