flutter 功能

flutter功能

带缓存的tab切换功能

使用PageController进行对应tab的widget缓存

dart 复制代码
late PageController _keepActiveVC;
 
  ///当前使用的视图索引
  late int _index;

  late PageController _keepActiveVC;

  /// 所有视图
  final List<Widget> _bodys = [];
  
  @override
  void initState() {
    super.initState();
    _index = 0;
    //页面控制器初始化
    _keepActiveVC = PageController(initialPage: _index );
  }
  
- @override
  Widget build(BuildContext context) {
    return Scaffold(body: _body(), bottomNavigationBar: _buildNavigationBar());
  }

  BottomNavigationBar _buildNavigationBar() {
    BottomNavigationBar bar = MyBottomNavigationBar(
     ......
      onTap: (i) {
        setState(() {
          _index = i;
          ///切换tab是跳转页面
          _keepActiveVC.jumpToPage(_index);
        });
      },
    );
    return bar;
  }
  
  Widget _body() {
    return PageView(
      ///禁用滚动
      physics: const NeverScrollableScrollPhysics(),
      controller: _keepActiveVC, //初始化的PageController
      children: _bodys, //当前所有视图的数组
      onPageChanged: (index) {
        _index = index; //切换选中的时候进行赋值
      },
    );

body中的子widget需要with AutomaticKeepAliveClientMixin ,并返回wantKeepAlive为true;

dart 复制代码
class _MyView extends State<MyView> with AutomaticKeepAliveClientMixin{
......
 @override
  bool get wantKeepAlive => widget.cacheWebView;
}

异常

Flutter 报错 setState() or markNeedsBuild() called during build

原因:视图未构建成功时调用了setState()或markNeedsBuild()方法

解决方法:

1.修改构建过程

2.使用官方提供了一个组件创建完成的回调通知方法

dart 复制代码
WidgetsBinding.instance.addPostFrameCallback((_) { 
       //需要创建的小组件
 });
相关推荐
无巧不成书02185 小时前
【开源鸿蒙+Flutter实战】Step Two复盘(DAY8-14)|复杂页面落地·多终端适配·状态保持实战指南
flutter·开源·harmonyos
sdff113965 小时前
【HarmonyOS】鸿蒙Flutter跨设备流转技术实战指南
flutter·wpf·harmonyos
岱宗夫up5 小时前
FastAPI入门(上篇):快速构建高性能Python Web API
开发语言·前端·python·fastapi
紫陌涵光6 小时前
112. 路径总和
java·前端·算法
无巧不成书02186 小时前
开源鸿蒙+Flutter实战复盘Step Three(DAY15-19)全场景动效·性能降级·工程闭环 终篇指南
flutter·开源·harmonyos
漠月瑾-西安6 小时前
CVE-2025-55182漏洞解析:你的React项目安全吗?
前端·安全·react.js
No丶slovenly6 小时前
flutter笔记-输入框
前端·笔记·flutter
国产化创客7 小时前
ESP32+Web实现智能气象站
前端·物联网·智能家居·智能硬件
阿林来了7 小时前
Flutter三方库适配OpenHarmony【flutter_speech】— 开发环境搭建
flutter·harmonyos·鸿蒙
coderYYY7 小时前
VSCode终端启动报错
前端·ide·vscode·npm·编辑器