前端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…

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/576147.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

运行django

确保app被注册 urls.py中编写url 视图对应关系 命令行启动 python manage.py runserver

“湘”约你我,“V”你而来!苏州金龙新V系客车闪耀星城

“湘”约你我、为你而来!4月24日,苏州金龙新V系智慧客车推介会走进星城长沙。来自湖南省内的160余位旅游客运行业协会及企业代表齐聚一堂,共同见证客车行业新质生产力标杆产品的无限魅力。 当前,湖南的旅游产业和道路运输业正处于…

每年首版次测试报告的要求有哪些?

每年首版次测试报告的要求可能因不同的地区、行业或产品而有所差异,但一般而言,它们通常遵循一些基本的标准和原则。以下是一些常见的首版次测试报告要求: 完整性:测试报告应包含所有必要的测试内容,包括但不限于测试…

意法半导体STM32F407VET6TR单片机优缺点、参数、应用和引脚封装

ST(意法半导体)的型号STM32F407VET6TR属于32位MCU微控制器,基于高性能的ArmCortex-M4 32位RISC核心,工作频率高达168MHz。单精度浮点单元(FPU)用于Cortex-M4核心,支持所有Arm单精度数据处理指令和数据类型。它还实现了一套完整的DSP指令和一个…

1-内核开发环境ubuntu+virtualbox+mobaXterm搭建

内核开发环境 ubuntuvirtualboxmobaXterm搭建 目录 内核开发环境 ubuntuvirtualboxmobaXterm搭建 1.virtualbox 安装 2.ubuntu 安装 3.网络设置 4.虚拟机安装ssh 服务,更新ubuntu 源安装基本软件 5.mobaXterm 个人免费版本安装 6.总结 本课程教程从0-1开始教…

NineData即将亮相2024中国移动算力网络大会,创始人CEO叶正盛带来《生态软件加速数据库国产替代》主题演讲

2024年4月28-29日,NineData即将亮相2024中国移动算力网络大会,创始人&CEO叶正盛将在「云原生数据库专场」带来《生态软件加速数据库国产替代》主题演讲。届时将和众多院士专家、行业大咖、业界伙伴一起探讨,并帮助企业提升数据库研发协同…

进口透明可视耐腐蚀PFA进样管特氟龙圆底试管适配MC-ICP-MS

PFA进样管可适配Neptune plus多接收器等离子质谱仪(MC-ICP-MS),广泛应用于地球化学、核保障、环境科学、金属组学领域,在生物、物理、化学、材料等多个学科的交叉方向也有良好的应用前景。 外观半透明,便于观察管内情…

【Moveit2】使用moveit_setup_assistant配置自己的机械臂功能包

【Moveit2】使用moveit_setup_assistant配置自己的机械臂功能包 文章目录 【Moveit2】使用moveit_setup_assistant配置自己的机械臂功能包1.确保你已经安装了moveit2环境2.配置机械臂功能包Reference 环境信息: ubuntu 22.04ros2 humblemoveit2 1.确保你已经安装了…

《佩德罗·巴拉莫》炽热的科马拉土地上,游荡的亡魂诉说着一切!

《佩德罗巴拉莫》炽热的科马拉土地上,游荡的亡魂诉说着一切! 胡安鲁尔福(1917-1986),墨西哥作家,代表作有《佩德罗巴拉莫》《燃烧的原野》《金鸡》,和诺奥克塔维奥帕斯、卡洛斯弗恩特斯并称为墨…

Redisson - tryLock 函数参数分析

这里有三个参数: waitTime:等待时间leaseTime:超时施放时间TimeUnit:时间单位 等待时间 如果 ABC… 多个线程去抢夺一把锁,A 成功了,如果设置的是 -1,那么 BCD... 就不等待,直接返…

使用CNN实现新闻文本分类

一、实验目的: 理解卷积神经网络的基本概念和原理;了解卷积神经网络处理文本数据的基本方法;掌握卷积神经网络处理文本数据的实践方法,并实现新闻文本的分类任务。 实验要求: 使用Keras框架定义并训练卷积神经网络模…

防盗链在nginx中如何配置,简单演示403forbidden的效果

一、使用场景: 资源被其他网站无端盗用 服务器压力无端增加 二、实现方法 1.valid_referers指令可以检测被访问资源从哪个地址来 2.通过referer头字段判断 3.若为空,报403错误 nginx的准备工作: 可以看 虚拟机中使用LNMP模拟跨域并结合…

书籍推推荐之二--《生命的色彩》

史钧《生命的色彩》 在生活中,我们会注意到一个有趣的现象:每个人的头发颜色各不相同,有黑色、灰色、黄色、棕红色、银白色等,但就是没有绿色。对于生活在丛林中的早期人类来说,绿色的头发简直就是天然的迷彩服&#x…

基于arcpro3.0.2版的使用深度学习检测对象之椰子树

基于arcpro3.0.2版的使用深度学习检测对象之椰子树 GPU显卡Nivda 1080 训练模型图 (四)检测对象之椰子树 使用深度学习检测对象 打开 detect objects using deep learning,参数 输入栅格为要检测的影像 模型定位为上一步输出的.emd文件 cpu模式Max Overlap Ratio0.4 运行时间…

C++感受6-Hello World 交互版

变量、常量输入、输出、流getline() 函数读入整行输入Hello() 函数复习新定义函数 Input() 实现友好的人机交互还有 “痘痘” 为什么挤不到的分析…… 1. DRY 原则简介 上一节课,我们写了两版“问候”程序。第一版的最大问题是重复的内容比较多,每一次问…

今日arXiv最热大模型论文:大模型也来看球,还能判断是否犯规

在足球世界,裁判的哨声可谓“千金难买”,因为它能直接决定俱乐部的钱包是鼓是瘪。但球场变化莫测,非常考验裁判的水平。 2022年卡塔尔世界杯上,半自动越位识别技术(SAOT)闪亮登场,通过12台摄像…

高并发场景中DB和Cache的一致性新的方案感想

拜读了: 美团2面:如何保障 MySQL 和 Redis 数据一致性?这样答,虐爆面试官这篇文章后的感想 高并发场景中数据库和缓存的一致性和可用性的感想 1,先更新缓存,再更新数据库1.1,前提1.2,理由1.2.1&…

Echarts-知识图谱

Echarts-知识图谱 demo地址 打开CodePen 效果 思路 1. 生成根节点 2. 根据子节点距离与根节点的角度关系,生成子节点坐标,进而生成子节点 3. 从子节点上按角度生成对应的子节点 4. 递归将根节点与每一层级子节点连线核心代码 定义节点配置 functio…

目标检测——大规模商品数据集

引言 亲爱的读者们,您是否在寻找某个特定的数据集,用于研究或项目实践?欢迎您在评论区留言,或者通过公众号私信告诉我,您想要的数据集的类型主题。小编会竭尽全力为您寻找,并在找到后第一时间与您分享。 …

阿里云企业邮箱API的使用方法?调用限制?

阿里云企业邮箱API性能如何优化?配置邮箱API的优势? 阿里云企业邮箱以其稳定、高效和安全的特点,受到了众多企业的青睐。而阿里云企业邮箱API的开放,更是为企业提供了更加灵活、便捷的管理和操作方式。下面,我AokSend…
最新文章