位置: 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家庭组怎么用)

  • 小规模纳税人收普票和专票有什么区别
  • 所得税费用调增分录
  • 一般纳税人的税收优惠政策
  • 服务型公司要交多少税
  • 年末是否结转本年利润
  • 个税预扣预缴扣除项目有哪些
  • 汇算清缴是不是按照审计报告
  • 年金是否一定是每年发生一次
  • 兼营和混合销售的联系
  • 资产负债表怎么看营业收入
  • 个人所得税租赁费的计算
  • 建筑设备租赁如何确定租赁期限
  • 小规模纳税人未开票收入填在哪里
  • 用友软件在哪里
  • 跨期列支成本费用危害
  • 建筑劳务公司业务范围是什么
  • 劳务派遣怎么做起来
  • 无偿划拨资产涉税问题
  • 税率修改后对价格的影响
  • 企业购买国债逆回购需要缴纳增值税吗
  • 所得税季度报表营业外收入填哪
  • 营改增后房产税计入什么科目
  • 业务招待费扣除计算举例说明
  • 应税凭证和纳税凭证的区别
  • 质量扣款不开票怎么处理
  • 应交税费属于什么费用科目
  • 怎么查以前申报的财务报表
  • 代开发票预缴的增值税能否申请退税
  • 小规模可以接收专票吗现在
  • 苹果手机miracast在哪里找到
  • 清理缓存网页电脑
  • 重装系统j
  • php aop
  • rundll32.exe进程很多
  • ipcservice.dll是什么?
  • vue项目上线教程
  • nginx反向代理详解
  • php生成颜色面板
  • 读懂spring源码
  • 权重下降是什么原因
  • shell中put命令
  • 网络销售平台优势和劣势
  • css content \f041
  • 小规模纳税人应交税费会计分录
  • 销售折扣 会计处理
  • 费用报销重复了怎么写情况说明
  • python condition
  • 残保金的滞纳金怎么算
  • 发行的企业债券属于所有者权益吗
  • 普通发票的开具规定是?
  • 购买银行理财产品安全吗
  • 什么叫境外地区
  • 未确认融资费用账务处理
  • 期末结转主营业务成本
  • 应缴国库款和应缴财政专户款有什么区别
  • 职工罚款的会计处理办法
  • 公司成立前购买的固定资产
  • 银行利息回单怎么报账审核
  • 零售行业折扣销售方案
  • 佣金付给别人公司合法吗
  • 简易征收计算企业所得税怎么算
  • 企业分红给个人的税收
  • 进项发票超过期限不认证怎么办
  • 货币资金核算内容
  • mysql批量修改字段值
  • mysql unique option prefix myisam_recover instead of myisam-recover-options的解决方法
  • sqlserver升级到2016
  • sql优化常用的15种方法
  • 微软的搜索网站
  • 配置是什么意思
  • innodb 结构
  • 组建,加入或退出工会都是基于
  • 什么是Shell,shell作用
  • linux timeline
  • node作为中间件做接口转发
  • Python 使用requests模块发送GET和POST请求的实现代码
  • android开发—01开发环境的搭建
  • 江苏省国税务局严三国
  • 营改增后租金如何交税
  • 异地预缴增值税销售额是含税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设