更高效的构建工具-vite

更高效的构建工具-vite

  • 前言
  • Vite是什么
  • Vite和webpack的比较
    • 1. 运行原理
    • 2. 使用成本
  • Vite的初体验

前言

首先我们要认识什么时构建工具?

企业级项目都具备什么功能呢?

  • Typescript:如果遇到ts文件,我们需要使用tsc将typescript代码转化为js代码;
  • React/Vue:如果使用前端框架需要安装react-complier / vue-complier,将我们的jsx文件/vue文件转换为render函数
  • less/sass/postcss/component-style:如果使用这些css预处理器,需要安装less-loadersass-loader等一系列编译工具;
  • 语法降级:Babel -->可能有部分浏览器还不支持新语法,所有我们还需将es的新语法转换到旧版本浏览器可以识别的语法格式;
  • 体积优化:uglifyjs / Terser --> 可以将我们的代码压缩成体积更小性能更高的文件;

如果我们稍微需要修改一些东西,都需要这么多东西的构建,非常麻烦~

现在有一个工具可以把tsc,vue-complier,less-loader,babel,terser等等都集成到一起,当代码更改时会自动将这些全部启动运行一遍。非常之轻松,这就是构建工具!!!

除了这些功能,一个构建工具还集成了:

  • 模块化开发支持:可以直接从node_modules引入代码;
  • 提高项目性能:压缩文件,代码分割;
  • 优化开发体验:
    • 会自动监听文件的变化,自动帮你调用所需要的处理工具并且进行重新打包( 整个过程叫做热更新(HRM)
    • 开发服务器:帮助我们解决跨域问题;为什么叫开发服务器呢? 因为服务器与服务器之间时不存在跨域问题的,所以本质上就是创建一个服务器帮助你去访问你访问不到的服务器;

Vite是什么

vite开发环境依赖esbuild进行预构建,生产环境则依赖rollup进行打包,并且充分利用了现代浏览器的特性,它是站在众多巨人肩膀上的一个产物,一个非常棒的前端项目的构建工具。vue-cli中已经将vite作为预设构建工具,如果我们使用vue-cli进行创建项目时,vue.config.js不再将时webpack的配置而是vite的配置。

Vite和webpack的比较

vite官方文档
当我们开始构建越来越大型的应用时,需要处理的 JavaScript 代码量也呈指数级增长。 包含数千个模块的大型项目相当普遍。基于 JavaScript 开发的工具就会开始遇到性能瓶颈:通常需要很长时间(甚至是几分钟!)才能启动开发服务器,即使使用模块热替换(HMR),文件修改后的效果也需要几秒钟才能在浏览器中反映出来。如此循环往复,迟钝的反馈会极大地影响开发者的开发效率和幸福感。

他们两种构建工具的侧重点不同,webpack更多的是关注兼容性,vite是更侧重于浏览器端的开发体验~

1. 运行原理

  • webpack
    在这里插入图片描述

当我们使用webpack启动项目时,webpack会根据我们配置文件(webpack.config.js) 中的入口文件(entry),分析出项目项目所有依赖关系,然后打包成一个文件(bundle.js),交给浏览器去加载渲染。项目越大,运行时间越长。

  • vite
    在这里插入图片描述
    使用vite运行项目时,首先会用esbuild进行预构建,将所有模块转换为es module,不需要对我们整个项目进行编译打包,而是在浏览器需要加载某个模块时,拦截浏览器发出的请求,根据请求进行按需编译,然后返回给浏览器。

2. 使用成本

  • webpack
    如果我们使用webpack自己去搭建项目脚手架时,需要配置比较多的东西, 比如:跨域、代码压缩、代码分割、css预处理器的代码转换、样式兼容性、vue/react代码解析、图片压缩、代码热更新、es降级、ts转换等等。

  • vite
    vite对我们常用功能都做了内置,比如:css 预处理器、html 预处理器、hash 命名、异步加载、分包、压缩、HMR等等,我们可以很轻松的通过配置项去配置。降低了我们的学习成本、增加了开发体验。

Vite的初体验

vite需要node.js版本18+,20+,请注意升级你的node版本

//使用 NPM:
$ npm create vite@latest//使用 Yarn:
$ yarn create vite//使用 PNPM:
$ pnpm create vite

这里需要输入项目名称,选择需要构建的框架以及需要使用的语言。

在这里插入图片描述
最后运行这上图的三条命令,构建速度也是非常的快~

在这里插入图片描述
创建成功的效果图如下图:

在这里插入图片描述



到这里vite的初步讲解就算结束了,创作不易,感谢支持!❤️❤️❤️

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android约束布局中用ConstraintHelper实现过渡动画效果

前些天发现了一个蛮有意思的人工智能学习网站,8个字形容一下"通俗易懂,风趣幽默",感觉非常有意思,忍不住分享一下给大家。 👉点击跳转到教程 一.创建一个类CircularRevealHelper继承ConstraintHelper代码如下 /*** Author: ly* Da…

【Linux从青铜到王者】 基础IO

本篇重点:文件描述符,重定向,缓冲区,磁盘结构,文件系统,inode理解文件的增删查改,查找一个文件为什么一定要有路径,动静态库,有的时候为什么找不到库,动态库的…

JavaWeb——003Axios Vue组件库(Element)

目录 一、Ajax 1、同步与异步​编辑 2、原生Ajax(繁琐)​编辑 2.1、写一个简易的Ajax 3、Axios(推荐使用)​编辑 3.1、Axios入门 3.2、Axios请求方式别名 3.3、案例:基于Vue及Axios完成数据的动态加载展示​编…

AIoT网关 人工智能物联网网关

AIoT(人工智能物联网)作为新一代技术的代表,正以前所未有的速度改变着我们的生活方式。在这个智能时代,AIoT网关的重要性日益凸显。它不仅是连接智能设备和应用的关键,同时也是实现智能化家居、智慧城市和工业自动化的必备技术。      一…

【linux进程间通信(二)】共享内存详解以及进程互斥概念

💓博主CSDN主页:杭电码农-NEO💓   ⏩专栏分类:Linux从入门到精通⏪   🚚代码仓库:NEO的学习日记🚚   🌹关注我🫵带你学更多操作系统知识   🔝🔝 进程间通信 1. 前言2. 共享内…

电脑录屏软件哪个好用?实测告诉你答案(2024年最新)

在当今信息化快速发展的时代,无论是录制在线课程、游戏操作,还是制作教程、会议记录,一款电脑录屏软件显得尤为重要,可是电脑录屏软件哪个好用呢?本文将介绍三款主流的电脑录屏软件,通过分步骤详细讲述&…

使用maven集成spring在测试的时候报出了如下的异常:version 60

使用maven集成spring在测试的时候报出了如下的异常: Caused by: java.lang.IllegalArgumentException: Unsupported class file major version 60 解决:

在word中将latex格式的公式转化为带有编号的mathtype公式

在word中将latex格式的公式转化为带有编号的mathtype公式 1.先在word里面配置好mathtype2.在word中设置mathtype的格式3.先将latex格式的公式转化为mathml格式4.读到这里,是不是觉得这个方法麻烦 1.先在word里面配置好mathtype 注意:1.word的版本应该是 …

基于springboot+vue的中小型医院网站(前后端分离)

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战,欢迎高校老师\讲师\同行交流合作 ​主要内容:毕业设计(Javaweb项目|小程序|Pyt…

Sovit3D数字孪生平台 助力智慧海上风电场项目加速

我们常说地球是蓝色星球,那是因为海洋约占地球面积的71%。如今,我国正在向“双碳”目标不断奋斗,海上风电也作为一种潜力清洁能源,迸发出前所未有的活力,海上吹来的风成为未来清洁能源新方向。 2024年海上风电项目加速…

Qt_快速安装指南

下载Qt在线安装程序(不仔细介绍)注册Qt账号(不仔细介绍)使用快速运行的命令,按照指定的下载地址下载 在Qt指定目录打开cmd命令窗口.\eqt-unified-windows-x86-4.0.1-1-online. exe --mirror https://mirrors.ustc.edu.…

JVM虚拟机结构

虚拟机结构图 从图中看出: JVM虚拟机主要有三大部分组成: 1. 类加载器 2. JVM运行时内存 3. 执行引擎 一、类加载器 类加载器主要用来加载字节码文件(.class)到内存中 二、内存结构 如图:可将内存分为两大部分&…

【学习iOS高质量开发】——协议与分类

文章目录 一、通过委托与数据源协议进行对象间通信1.委托模式2.要点 二、将类的实现代码分散到便于管理的数个分类之中1.如何实现2.要点 三、总是为第三方类的分类名称加前缀1.为什么总是为第三方类的分类名称加前缀2.要点 三、勿在分类中声明属性1.勿在分类中声明属性的原因2.…

Android进阶(二十九) 走近 IntentFilter

文章目录 一、什么是IntentFilter ?二、IntentFilter 如何过滤隐式意图?2.1 动作测试2.2 类别测试2.3 数据测试 一、什么是IntentFilter ? 如果一个 Intent 请求在一片数据上执行一个动作, Android 如何知道哪个应用程序&#xf…

Spring Boot中实现列表数据导出为Excel文件

点击下载《Spring Boot中实现列表数据导出为Excel文件》 1. 前言 本文将详细介绍在Spring Boot框架中如何将列表数据导出为Excel文件。我们将通过Apache POI库来实现这一功能,并解释其背后的原理、提供完整的流程和步骤,以及带有详细注释的代码示例。最…

关于设备连接有人云的使用及modbus rtu协议,服务器端TCP调试设置

有人云调试 调试过程问题1. 关于modbus rtu协议,实质上有三种modbus基本原理modbus 格式2. 关于modbus crc16通信校验3. 关于在ubuntu阿里云服务器端,监听网络数据之调试mNetAssist之前的一个项目,再拿出来回顾下。 调试过程 先 要在有人云,用手机号注册一个服务账号,官网显…

家的情感记忆:如何用壁纸讲述你的墙故事?

1、方小童在线工具集 网址: 方小童 该网站是一款在线工具集合的网站,目前包含PDF文件在线转换、随机生成美女图片、精美壁纸、电子书搜索等功能,喜欢的可以赶紧去试试!

HarmonyOS—使用预览器查看应用/服务效果

DevEco Studio为开发者提供了UI界面预览功能,可以查看应用/服务的UI界面效果,方便开发者随时调整界面UI布局。预览器支持布局代码的实时预览,只需要将开发的源代码进行保存,就可以通过预览器实时查看应用/服务运行效果&#xff0c…

探索分布式强一致性奥秘:Paxos共识算法的精妙之旅

提到分布式算法,就不得不提 Paxos 算法,在过去几十年里,它基本上是分布式共识的代名词,因为当前一批常用的共识算法都是基于它改进的。比如,Fast Paxos 算法、Cheap Paxos、Raft 算法等。 由莱斯利兰伯特(L…

Spring6学习技术|AOP

学习材料 尚硅谷Spring零基础入门到进阶,一套搞定spring6全套视频教程(源码级讲解) AOP AOP(Aspect Oriented Programming)是一种设计思想,是软件设计领域中的面向切面编程,它是面向对象编程的…