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

  • 企业转出多交增值税吗
  • 税后经营净利率和营业净利率的区别
  • 小规模纳税人劳务分包税率
  • 酒店物料消耗包括哪些
  • 员工预支薪金怎么记账
  • 长期借款科目核算的是企业的长期借款本金和利息
  • 劳务支付
  • 装修项目展示厅费用支出列什么科目?
  • 多出来的费用
  • 小规模建筑企业预缴税款
  • 一般纳税人转出进项税额
  • 出口企业应交税费是负数怎么解释
  • 固定资产加速折旧最新政策2023
  • 无偿提供服务需要交增值税吗
  • 小规模纳税人取得专票如何处理
  • 电子发票记账联怎么入账
  • 房屋维修费属于固定资产吗
  • linux使用cp
  • 完税凭证遗失后怎么处理
  • win11系统怎么删除账户
  • 房屋装修补偿款 避税
  • 残疾人就业保障金
  • php安装扩展fileinfo
  • 预提收入需不需要计提增值税
  • opencv如何使用
  • laravel app接口
  • Vue3通透教程【十四】TS复杂类型详解(一)
  • php模板引擎原理
  • 六自由度机器人简图
  • 在国内如何用ChatGPT
  • 命令default
  • 印花税账务处理会计分录
  • 固定资产的装修费计入固定资产吗
  • 劳务费发票是不是专票
  • mysql动态表单设计与实现
  • 富文本word
  • dedecms怎么改图片
  • 小规模纳税人劳保用品可以抵扣吗
  • 个体户餐饮服务包括哪些经营范围
  • 本期应补退税额就是交钱吗
  • 价外费用企业所得税
  • 股权转让溢价款缴纳增值税
  • 盈利和亏损怎么计算
  • 摊销期在一年以内房租的账务处理
  • 金融资产是分为哪三分类?
  • 承兑汇票利息分录
  • 现在增值税是多少个点
  • 堤防维护费税率
  • 事业单位项目结算审计报告
  • 劳动仲裁要出面吗
  • 代金券消费怎么入账
  • 劳动关系与劳务关系的联系与区别
  • 销售返利怎么做税务处理
  • 货物发出退货
  • 建筑劳务公司的会计账务处理
  • 企业盘盈盘亏的固定资产先要计入待处理财产损益
  • 新设企业如何建账
  • mysql怎么使用索引
  • win10系统共享打印机无法访问怎么解决
  • Win10 Mobile 14393.321终于修复Lumia636/638导航栏遮挡
  • win7系统点击桌面图标没反应
  • mac使用命令行
  • lumia950升级win11
  • win8.1新建桌面
  • windos10正式版
  • linux硬盘io
  • cmd运行指令闪黑框
  • unity5.x游戏开发指南
  • linux中tar命令
  • 局域网如何打开共享文件夹
  • angular页面加载完后执行方法
  • cmd 更改密码
  • html css js 实战案例
  • javascript教程推荐知乎
  • 如何用python创建数据集
  • 贵州省发票流向查询
  • 灯具维修发票明细
  • 日照公交305发车时间表
  • 如何挑选烟叶等级
  • 湖北注册税务师协会
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设