当前位置: 首页 > news >正文

Flutter鸿蒙next 状态管理高级使用:深入探讨 Provider

✅近期推荐:求职神器

https://bbs.csdn.net/topics/619384540


🔥欢迎大家订阅系列专栏:flutter_鸿蒙next
💬淼学派语录:只有不断的否认自己和肯定自己,才能走出弯曲不平的泥泞路,因为平坦的大路,太tm无趣了!

目录

写在前面

一、Provider 概述

二、Provider 的基本用法回顾

三、高级用法

1. 组合多个 Provider

2. 使用 Provider 的 Selector

3. 使用 ChangeNotifierProxyProvider

4. 自定义 Provider

写在最后


写在前面

在 Flutter 开发中,状态管理是一个至关重要的主题。Flutter 提供了多种状态管理方案,其中 Provider 是最流行和灵活的选择之一。本文将深入探讨 Provider 的高级用法,以帮助开发者更好地理解和应用这一强大的状态管理工具。

一、Provider 概述

Provider 是一个 Flutter 插件,旨在简化状态管理。它通过依赖注入和通知机制,使得构建响应式应用变得更加容易。Provider 的核心理念是将数据和状态集中管理,并使这些数据能在不同的 Widget 树中共享。

二、Provider 的基本用法回顾

在开始高级用法之前,让我们回顾一下 Provider 的基本用法。

  1. 安装 Provider

    pubspec.yaml 中添加依赖:

    yaml

    dependencies: flutter: sdk: flutter provider: ^6.0.0
  2. 创建一个模型类

    创建一个简单的计数器模型:

    import 'package:flutter/material.dart';class Counter with ChangeNotifier {int _count = 0;int get count => _count;void increment() {_count++;notifyListeners();}
    }
    

  3. 使用 Provider 提供状态

    main.dart 中使用 Provider 包裹你的应用:

    void main() {runApp(ChangeNotifierProvider(create: (context) => Counter(),child: MyApp(),),);
    }
    

  4. 在 Widget 中消费状态

    在需要的地方使用 ConsumerProvider.of 来获取状态:

    class MyHomePage extends StatelessWidget {@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text('Provider Example'),),body: Center(child: Consumer<Counter>(builder: (context, counter, child) {return Text('Count: ${counter.count}');},),),floatingActionButton: FloatingActionButton(onPressed: () {Provider.of<Counter>(context, listen: false).increment();},child: Icon(Icons.add),),);}
    }
    

三、高级用法

1. 组合多个 Provider

在复杂的应用中,可能会有多个状态需要管理。Provider 允许你将多个 Provider 组合使用。

class User with ChangeNotifier {String _name = '';String get name => _name;void updateName(String newName) {_name = newName;notifyListeners();}
}// 在 main.dart 中组合多个 Provider
void main() {runApp(MultiProvider(providers: [ChangeNotifierProvider(create: (context) => Counter()),ChangeNotifierProvider(create: (context) => User()),],child: MyApp(),),);
}

通过 MultiProvider,你可以在同一个 Widget 树中使用多个状态。

2. 使用 Provider 的 Selector

当你只想监听某个模型的特定属性时,可以使用 Selector,这可以提高性能。

Selector<Counter, int>(selector: (context, counter) => counter.count,builder: (context, count, child) {return Text('Count: $count');},
);

Selector 只会在选择的属性变化时重新构建,因此在某些情况下,可以减少不必要的 Widget 重建。

3. 使用 ChangeNotifierProxyProvider

当一个模型依赖于另一个模型时,可以使用 ChangeNotifierProxyProvider。这使得依赖关系管理变得更加清晰。

class AuthService with ChangeNotifier {String _userId;String get userId => _userId;void login(String id) {_userId = id;notifyListeners();}
}class UserProfile with ChangeNotifier {final AuthService authService;UserProfile(this.authService);String get profile => 'Profile for user: ${authService.userId}';
}// 在 main.dart 中使用 ChangeNotifierProxyProvider
void main() {runApp(ChangeNotifierProvider(create: (context) => AuthService(),child: ChangeNotifierProxyProvider<AuthService, UserProfile>(create: (context) => UserProfile(Provider.of<AuthService>(context, listen: false)),update: (context, authService, userProfile) => UserProfile(authService),child: MyApp(),),),);
}

这样,UserProfile 就可以直接访问 AuthService 的状态。

4. 自定义 Provider

如果你有特定的需求,可以创建自己的 Provider。以下是一个简单的示例,使用 ValueNotifier 来实现一个计数器。

class CustomCounterProvider extends ValueNotifier<int> {CustomCounterProvider() : super(0);void increment() {value++;}
}// 使用自定义 Provider
void main() {runApp(ChangeNotifierProvider(create: (context) => CustomCounterProvider(),child: MyApp(),),);
}// 在 Widget 中使用
ValueListenableBuilder<int>(valueListenable: Provider.of<CustomCounterProvider>(context),builder: (context, count, child) {return Text('Count: $count');},
);

写在最后

Provider 是 Flutter 状态管理的一个强大工具,适用于各种复杂程度的应用。通过组合多个 Provider、使用 SelectorChangeNotifierProxyProvider,你可以创建一个高效、可维护的应用。

对于大多数应用而言,Provider 提供了一种优雅而强大的方式来管理状态。随着你对 Flutter 和 Provider 的深入理解,你将能够构建出更复杂和功能丰富的应用。

http://www.lryc.cn/news/469632.html

相关文章:

  • JMeter实战之——模拟登录
  • 智能台灯设计(一)原理图设计
  • 数据库查询返回结果集及其元数据信息:ResultSet 和 ResultSetMetaData 深度解析
  • 2.插入排序(斗地主起牌)
  • 漫谈编程小白如何成为大神:夯实基础,开启通神之路
  • 基于机器学习的个性化电影推荐系统【源码+安装+讲解+售后+文档】
  • 企业如何配合好等级保护测评工作?
  • Could not find artifact cn.hutool:hutool-all:jar:8.1 in central 导入Hutool报错
  • 【功能安全】汽车功能安全个人认证证书
  • axios直接上传binary
  • 量化交易API接口是什么?如何申请和应用?
  • 语义分割:YOLOv11的分割模型训练自己的数据集(从代码下载到实例测试)
  • Python爬虫:从入门到精通
  • Web组态软件
  • Java中为什么要私有化构造方法
  • 【大数据学习 | kafka】kafuka的基础架构
  • 2-petalinux2018.3摸索记录-petalinux rootfs
  • RHCE作业二
  • GPS/北斗时空安全隔离装置(卫星时空防护装置)使用手册
  • 【C++篇】深度解析类与对象(下)
  • 【gRPC】什么是RPC——介绍一下RPC
  • 谈谈你对AQS的理解
  • Bitcoin全节点搭建
  • 【mysql进阶】4-6. InnoDB 磁盘文件
  • HexForge:一款用于扩展安全汇编和十六进制视图的IDA插件
  • WORFBENCH:一个创新的评估基准,目的是全面测试大型语言模型在生成复杂工作流 方面的性能。
  • SpringBoot 集成 Activiti 7 工作流引擎
  • UVM初学篇 -(22)UVM field_automation 域的自动化机制
  • STL二分查找
  • 啤酒游戏—企业经营决策沙盘