Flutter-性能优化:图片占位符、预缓存和禁用导航过渡动画
最后我想说:对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,
return AnimatedSwitcher(
duration: const Duration(milliseconds: 500),
child: frame != null ? child : placeholder,
);
}
},
);
}
}
有了占位符,布局再也不会跳来跳去了,而且图片也有了渐现效果:

预缓存图片
如果你的 app 在显示图片界面之前有欢迎界面,你可以调用 precacheImage 方法来预缓存图片。
precacheImage(NetworkImage(url), context);
来看一下效果:

在 Flutter web app 中禁用导航过渡动画
导航过渡动画一般在用户切换页面时使用,在移动 app 中,这种方式可以很好地让用户知道知道自己在哪里。但是,在 web 中,很少看到这样的交互。所以为了提高感知性能,你可以禁用页面间的过渡动画。
默认情况下, MaterialApp 会根据不同平台来使用不同的过渡动画(Android 向上滑动,而 iOS 是向右(左)滑动)。为了覆盖这个默认行为,你需要创建自定义的 PageTransitionsTheme 类。你可以使用 kIsWeb 常量来判断 app 是否在 web 中运行。如果是,通过返回 child 来禁用过渡动画:
import ‘package:flutter/foundation.dart’;
import ‘package:flutter/material.dart’;
class NoTransitionsOnWeb extends PageTransitionsTheme {
@override
Widget buildTransitions(
route,
context,
animation,
secondaryAnimation,
child,
) {
if (kIsWeb) {
return child;
}
return super.buildTransitions(
route,
context,
animation,
secondaryAnimation,
child,
);
}
}
设置 MaterialApp 的 pageTransitionsTheme 选项:
MaterialApp(
theme: ThemeData(
pageTransitionsTheme: NoTransitionsOnWeb(),
),
)
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。



由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
写在最后
最后我想说:对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们!
这里附上上述的技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。
相信它会给大家带来很多收获:


上述【高清技术脑图】以及【配套的架构技术PDF】可以点击下面链接免费获取
脑图】以及【配套的架构技术PDF】可以点击下面链接免费获取**
当程序员容易,当一个优秀的程序员是需要不断学习的,从初级程序员到高级程序员,从初级架构师到资深架构师,或者走向管理,从技术经理到技术总监,每个阶段都需要掌握不同的能力。早早确定自己的职业方向,才能在工作和能力提升中甩开同龄人。
更多推荐


所有评论(0)