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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推