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以内,第一阶段加载速度优化完成。

相关推荐
天若有情67318 小时前
前端HTML精讲03:页面性能优化+懒加载,搞定首屏加速
前端·性能优化·html
亚历克斯神19 小时前
Flutter for OpenHarmony: Flutter 三方库 mutex 为鸿蒙异步任务提供可靠的临界资源互斥锁(并发安全基石)
android·数据库·安全·flutter·华为·harmonyos
钛态19 小时前
Flutter 三方库 smartstruct 鸿蒙化字段映射适配指南:介入静态预编译引擎扫除视图及数据模型双向强转类型错乱隐患,筑稳如磐石的企业级模型治理防线-适配鸿蒙 HarmonyOS ohos
flutter·华为·harmonyos
键盘鼓手苏苏19 小时前
Flutter 组件 csv2json 适配鸿蒙 HarmonyOS 实战:高性能异构数据转换,构建 CSV 流式解析与全栈式数据映射架构
flutter·harmonyos·鸿蒙·openharmony
左手厨刀右手茼蒿19 小时前
Flutter 组件 http_requests 适配鸿蒙 HarmonyOS 实战:极简网络请求,构建边缘端轻量级 RESTful 通讯架构
网络·flutter·http
雷帝木木19 小时前
Flutter 三方库 hrk_logging 的鸿蒙化适配指南 - 实现标准化分层日志记录、支持多目的地输出与日志分级过滤
flutter·harmonyos·鸿蒙·openharmony·hrk_logging
左手厨刀右手茼蒿19 小时前
Flutter 三方库 dio_compatibility_layer 的鸿蒙化适配指南 - 实现 Dio 跨主版本的平滑迁移、支持遗留拦截器兼容与网络请求架构稳定升级
flutter·harmonyos·鸿蒙·openharmony·dio_compatibility_layer
雷帝木木19 小时前
Flutter 三方库 hashids2 基于鸿蒙安全内核的深度隐匿映射适配:数字指纹泄露防御层、生成短小精悍唯一不可逆加盐哈希,护航全链路请求 URL 隐私-适配鸿蒙 HarmonyOS ohos
安全·flutter·harmonyos
bjzhang7521 小时前
使用 HTML + JavaScript 实现 SQL 智能补全功能
javascript·html·sql智能补全
天若有情67321 小时前
前端HTML精讲01:别再乱 div 一把抓,吃透语义化标签才是进阶第一步
前端·html