位置: IT常识 - 正文

vite项目优化(项目优化管理工具)

编辑:rootadmin
vite项目优化

推荐整理分享vite项目优化(项目优化管理工具),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:项目优化设计,项目优化方法,优化项目 英文,项目优化是什么,web项目优化,项目优化是什么,vericut优化,项目优化管理工具,内容如对您有帮助,希望把文章链接给更多的朋友!

首先在讲述vite优化之前,我们先来分析一下和传统的项目管理构建工具的区别,以webpack为例,它是利用plugin插件和loader加载器对项目的所有模块和依赖统一通过入口文件进行编译,从而变成我们html所需要的js格式渲染我们的页面。

随着浏览器的发展,逐渐的已经支持了 ES 模块

因此Vite在设计时考虑在浏览器请求源码时进行转换并按需提供源码。根据情景动态导入代码,即只在当前屏幕上实际使用时才会被处理。

vite项目优化(项目优化管理工具)

优势: 这样就避免了随着应用体积的增大,导致了启动服务缓慢,一处代码更新界面需要数秒钟才能显示的问题。运行速度真的没得说。

同样的,作为一个新型的构建框架,也有很多的弊端。 缺点: 只能针对现代浏览器(ES2015+)、生态小等。

当然我们今天说的不止是这些,既然选择了vite框架,自然不会考虑浏览器的兼容性,我们更多的还是关注vite本身的性能。

优势即劣势

正是因为vite本身是动态加载的资源,当某个路由的依赖项比较多的时候,加上你可能使用了某些组件库的按需加载(比如element-plus),在进入页面时可谓是很慢,而且页面都是会像卡壳了一样刷新一次。

技术层观察的表现是,network加载了很多资源,同时在cmd终端会显示:

下午7:01:09 [vite] ✨ new dependencies optimized: element-plus/es/components/message-box/style/index下午7:01:09 [vite] ✨ optimized dependencies changed. reloading下午7:01:23 [vite] ✨ new dependencies optimized: element-plus/es/components/form/style/index下午7:03:57 [vite] vite.config.ts changed, restarting server...

这是因为需要按需写入组件与样式导致的,那么怎么解决这一问题呢,我们更希望在开发环境下,能提高我们的运行速度,而且让生成环境的包体积更小。然而,好像没有太好的解决方案,因为第一次按需加载按照vite的设计就必须要写入。

换个思路,那么我只能在开发环境下全局加载组件,打包时再执行按需加载了…

// 自定义插件 ./plugins/fullImportPluginimport * as path from 'path'import type { Plugin, ResolvedConfig } from 'vite'export default function fullImportPlugin () { let config: ResolvedConfig return <Plugin>{ name: 'fullImportElementPlus', async configResolved (conf) { config = conf }, transform (code, id) { // 判断当前处理的是否是 _src/main.ts_ if (path.join(config.root, 'src/main.ts') === id) { const name = 'ElementPlus' // 引入 ElementPlus 和 样式 const prepend = `import ${name} from 'element-plus';\nimport 'element-plus/theme-chalk/src/index.scss';\n` code = code.replace('.mount(', ($1) => `.use(${name})` + $1) return prepend + code } return code } }}// vite.config.tsimport { ElementPlusResolver } from 'unplugin-vue-components/resolvers'import unElementPlus from 'unplugin-element-plus/vite'import unComponents from 'unplugin-vue-components/vite'import fullImportPlugin from './plugins/fullImportPlugin'const config = {plugins:[]}if ( modes === 'development'){ config.plugins.push(fullImportPlugin())} else { config.plugins.push(unElementPlus({ useSource: true })) config.plugins.push(unComponents({ dirs:[], dts: true, resolvers: [ ElementPlusResolver() ] }))}export default config
本文链接地址:https://www.jiuchutong.com/zhishi/284109.html 转载请保留说明!

上一篇:最亮的投影机是什么(投影仪哪种光源亮度高)

下一篇:Win7系统利用家庭组把多台电脑资源共享的方法(win7家庭组怎么用)

  • 一般纳税人开出的普票算销项税额吗
  • 价税合计金额怎么算出税额
  • 发票只有抵扣联没有发票联能不能报销
  • 工程项目成本控制的方法
  • 企业购买的商业保险赔偿多少
  • 退休工资怎样扣社保
  • 委托在建工程会计分录
  • 城镇土地使用税暂行条例
  • 冲减产品成本会计分录
  • 因增资扩股导致股价下跌
  • 新成立公司没有财务报表情况说明
  • 退货但发票不冲销
  • 跨月负数发票会计分录
  • 增值税专用发票和普通发票的区别
  • 小规模纳税人一个季度多少免税
  • 融资租入的固定资产视为承租企业的资产体现了什么原则
  • etc充值发票可以抵扣税吗
  • 接管财务要对接哪些内容?
  • 非营利组织企业所得税政策
  • 一般纳税人增值税结转账务处理
  • 鸿蒙工具箱巅峰模式有什么用
  • msdn原版win7
  • 怎么给文件添加属性
  • 收取个人挂靠的管理费用要交税吗?
  • 企业的税收优惠政策有哪些
  • 债务人以固定资产债务重组
  • 海恩斯科普简介
  • 小狐狸803050
  • 总公司下的分公司如何做账
  • 控制器操作视频
  • 小程序从入门到精通
  • 律师事务所主要业务范围介绍
  • 帝国cms模板文件在哪
  • 办营业执照怎么填写经营范围
  • 公司赠送客户的产品怎么核算
  • linux db2安装与配置
  • 小规模纳税人进项发票怎么做账
  • 会计学中的折旧是什么意思
  • mysql数据库性能监控
  • 成品油发票怎么录入库存
  • 进项票可以抵扣企业所得税吗
  • 工资不计提直接做管理费用可以吗
  • 进出口贸易公司取名字大全
  • 费用少计提了怎么办
  • 软件增值税即征即退税务风险
  • 应收账款期末余额为负数表示什么
  • 开具正数发票中如何体现扣款?
  • 返利开红字发票怎么做账
  • 餐费补贴是否计入成本
  • 劳务派遣期限是什么意思
  • 免抵退怎么理解
  • 可以抵扣的增值税进项税额
  • 支付销售途中运费怎么算
  • 建筑企业工程施工科目怎么结转
  • 进口固定资产的汇率怎么算
  • mysql理论知识
  • 苹果的mac系统
  • 如何编译安装
  • win8.1怎么关机快捷键
  • windows xp无法更改密码
  • win7 c盘莫名其妙满了
  • 如何解除系统默认
  • linux命令行技巧
  • 场景切换方式
  • opengl教学视频
  • 深入剖析kubernetes pdf
  • python有没有翻译库
  • js存储
  • javascript闭包详解
  • python数据结构教程
  • python编程
  • 零基础玩转python
  • vue router使用query和params传参的使用和区别
  • jquery 入门
  • rsa加密算法python
  • python爬虫代码怎么写
  • 陕西省国家励志奖学金证书查询入口
  • 北京地税局上班时间查询
  • 国家税务总局对税务助征员
  • 减免税办理
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设