Flutter页面状态保留策略

目的: 防止每次点击底部按钮都进行一次页面渲染和网络请求

1. 使用IndexedStack

简单,只需要把被渲染的组件外部套一层IndexedStack即可

缺点: 在应用启动的时候,所有需要保存状态的页面都会直接被渲染,保存起来. 对性能有影响

2. 使用PageController

实现较为复杂,但是不用应用启动就全部加载

PageController实现页面状态保留步骤:

  1. 将要进行状态保留的页面使用PageView包裹,其中需要最少两个参数:controller和children. children就是要渲染的页面. controller需要自定义
  2. 自定义controller
  3. 在被渲染的页面中with AutomaticKeepAliveClientMixin 类, 重写 get方法进行配置,build方法中调用super.builder(context)


    ps: 前两步骤是在外层组件中设置的,如:foot组件Tabs, 在Tabs中渲染页面,如Home. 第三步则是在Home中完成
相关推荐
cici158746 分钟前
非线性模型预测控制(NMPC)基于CasADi的MATLAB实现
开发语言·matlab
独特的螺狮粉18 分钟前
开源鸿蒙跨平台Flutter开发:量子态波函数坍缩系统-波动力学与概率云渲染架构
开发语言·flutter·华为·架构·开源·harmonyos
浮芷.23 分钟前
Flutter 框架跨平台鸿蒙开发 - 思维录音机应用
flutter·华为·harmonyos
冰暮流星27 分钟前
javascript之dom访问属性
开发语言·javascript·dubbo
lsx20240628 分钟前
SQL Auto Increment 自动增长
开发语言
浮芷.30 分钟前
Flutter 框架跨平台鸿蒙开发 - 数字遗嘱应用
flutter·华为·harmonyos
t1987512830 分钟前
MATLAB模糊数学模型(Fuzzy Mathematical Model)实现指南
开发语言·matlab
一只小阿乐30 分钟前
TypeScript中的React开发
前端·javascript·typescript·react
Highcharts.js34 分钟前
Highcharts客户端导出使用文档说明|图表导出模块讲解
前端·javascript·pdf·highcharts·图表导出
2501_9219308336 分钟前
Flutter for OpenHarmony三方库适配实战:file_selector文件选择详解
flutter·openharmony