Flutter开发进阶之Flutter Web加载速度优化

Flutter开发进阶之Flutter Web加载速度优化

通常使用Flutter开发的web加载速度会比较慢,原因是Flutter web需要加载的资源处于国外,以下是据此所做的相应优化。

一、FlutterWeb打包

flutter build web --web-renderer canvaskit

使用新命令打包

flutter build web --web-renderer canvaskit --no-tree-shake-icons --no-tree-shake-icons

二、进行本地调试

cd build/web
python3 -m http.server 8080

启动本地服务

三、获取本机地址ip

ipconfig getifaddr en0

四、浏览器加载web

以上通过获取本地ip和启动端口为8080的服务得到局域网内链接

通过浏览器查看web相关文件耗时

通过查看得知有三个文件耗时比较突出

canvaskit.js

https://www.gstatic.com/flutter-canvaskit/a794cf2681c6c9fe7b260e0e84de96298dc9c18b/chromium/canvaskit.js

KFOmCnqEu92Fr1Me5WZLCzYlKw.ttf

https://fonts.gstatic.com/s/roboto/v20/KFOmCnqEu92Fr1Me5WZLCzYlKw.ttf

canvaskit.wasm

https://www.gstatic.com/flutter-canvaskit/a794cf2681c6c9fe7b260e0e84de96298dc9c18b/chromium/canvaskit.wasm

五、修改加载路径

canvaskit.js和canvaskit.wasm在本地路径下有对应文件但是还是从线上拿去最新的文件

可以通过打包命令修改其加载路径,得到最终的打包命令为

flutter build web --web-renderer canvaskit --dart-define=FLUTTER_WEB_CANVASKIT_URL=/canvaskit/ --no-tree-shake-icons --no-tree-shake-icons

本地并未生成KFOmCnqEu92Fr1Me5WZLCzYlKw.ttf,我们可以通过预先下载文件,放在web路径下

重新执行打包命令,最终打包结果如下

查看main.dart.js文件,查找到KFOmCnqEu92Fr1Me5WZLCzYlKw.ttf

修改路径为相对路径

六、比对结果

重新从浏览器加载网页

canvaskit.js 323ms->3ms

KFOmCnqEu92Fr1Me5WZLCzYlKw.ttf 376ms->6ms

canvaskit.wasm 661ms->39ms

整体文件加载时长从超过500ms减少到50ms以内,第一阶段加载速度优化完成。

相关推荐
NoBarLing1 小时前
python将目录下的所欲md文件转化为html和pdf
python·pdf·html
weixin_460783872 小时前
Flutter解决TabBar顶部页面切换导致页面重载问题
android·javascript·flutter
火柴就是我8 小时前
flutter rust bridge 编译成so 文件 或者 .a文件 依赖到主项目
flutter·ios·rust
pengyu9 小时前
系统化掌握Flutter组件之Transform:空间魔法师
android·flutter·dart
码农研究僧9 小时前
Uniapp 页面返回不刷新?两种方法防止 onShow 触发多次请求!
uni-app·vue·html·onshow
坚果的博客10 小时前
鸿蒙版Flutter快递查询助手
flutter·华为·harmonyos
晴天学长11 小时前
一个多功能的GetX 项目代码生成工具
前端·flutter
蜡笔小新..12 小时前
Windows下配置Flutter移动开发环境以及AndroidStudio安装和模拟机配置
windows·flutter
vvilkim13 小时前
使用 JavaScript 和 HTML5 实现强大的表单验证
开发语言·javascript·html5
不会聊天真君64713 小时前
HTML5(Web前端开发笔记第一期)
笔记·html5