`
ipython
  • 浏览: 295141 次
  • 性别: Icon_minigender_1
  • 来自: 佛山
社区版块
存档分类
最新评论

flutter provider 5.0 状态管理学习

阅读更多

Flutter Provider 5.0 学习

 

下面是修改过的provider 官方例子代码:

import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'dart:math';

void main() {
  runApp(
    MultiProvider(
      providers: [
        ChangeNotifierProvider(create: (_) => Counter()),
        ChangeNotifierProvider(create: (_) => Person()),
      ],
      child: const MyApp(),
    ),
  );
}

class Counter with ChangeNotifier {
  int _count = 0;
  int get count => _count;
  String _name = 'Michael';
  String get name => _name;

  void increment() {
    _count++;
    notifyListeners();
  }

  void setName (int i) {
    _name = '$name $i';
    notifyListeners ();
  }
}

class Person with ChangeNotifier {
  int _age = 18;
  int get age => _age;
  String _name = '1';
  String get name => _name;

  void changeName () {
    var r = Random();
    _name = 'Student: ${r.nextInt(100)}';
    notifyListeners();
  }
  void changeAge () {
    var r = Random();
    _age  = r.nextInt(100);
    notifyListeners();
  }
}

class MyApp extends StatelessWidget {
  const MyApp({Key key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return const MaterialApp(
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatelessWidget {
  const MyHomePage({Key key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    print ('build home page');
    return Scaffold(
      appBar: AppBar(
        title: const Text('Provider 5.0 Example'),
      ),
      body: Center(
        child: Column(
          mainAxisSize: MainAxisSize.min,
          mainAxisAlignment: MainAxisAlignment.center,
          children: const <Widget>[
            Text('You have pushed the button this many times:'),
            Count(),
            ShowName(),
            ShowAge(),
            ShowPersonName(),
            ShowPersonName2(),
            ShowPersonAge (),
            ShowPersonAge2(),
            ChangePersonName(),
            ChangePersonAge (),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        key: const Key('increment_floatingActionButton'),
        onPressed: () => context.read<Counter>().increment(),
        tooltip: 'Increment',
        child: const Icon(Icons.add),
      ),
    );
  }
}

class Count extends StatelessWidget {
  const Count({Key key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    return Text(
        '${context.watch<Counter>().count}',
        key: const Key('counterState'),
        style: Theme.of(context).textTheme.headline4);
  }
}

class ShowName extends StatelessWidget {
  const ShowName({Key key}) : super(key:key);
  @override
  Widget build(BuildContext context) {
    print ('show name');
    return Text(
      '${context.watch<Counter>().name}',
    );
  }
}

class ShowAge extends StatelessWidget {
    const ShowAge ({Key key}):super(key:key);
    @override
    Widget build (BuildContext context) {
        print ('show age');
        return new Center(
            child: new Text('show Age', style: new TextStyle(fontSize: 32.0))
        );
    }
}

class ShowPersonName extends StatelessWidget {
    const ShowPersonName ({Key key}):super(key:key);
    @override
    Widget build (BuildContext context) {
        print ('show person name');
        final personName = context.select((Person p) => p.name ); // 采用select 方式,绑定Person的name属性,只有name属性的值改变了,才刷新本widget
        return new Center(
            child: new Text('Person Name: ${personName}', style: new TextStyle(fontSize: 32.0))
        );
    }
}

class ShowPersonAge extends StatelessWidget {
    const ShowPersonAge ({Key key}):super(key:key);
    @override
    Widget build (BuildContext context) {
        print ('show person age');
        final personAge = context.select((Person p)=>p.age);  // 采用select 方式,绑定Person的age属性,只有age属性的值改变了,才刷新本widget, 推荐这用法
        return new Center(
            child: new Text('Person Age: ${personAge}', style: new TextStyle(fontSize: 32.0))
        );
    }
}

class ShowPersonName2 extends StatelessWidget {
    const ShowPersonName2 ({Key key}):super(key:key);
    @override
    Widget build (BuildContext context) {
        print ('show person name 2');
        return new Center(
            child: new Text('Person Name: ${context.watch<Person>().name}', style: new TextStyle(fontSize: 32.0))
        );
    }
}

class ShowPersonAge2 extends StatelessWidget {
    const ShowPersonAge2 ({Key key}):super(key:key);
    @override
    Widget build (BuildContext context) {
        print ('show person age 2');
        return new Center(
            child: new Text('Person Age: ${context.watch<Person>().age}', style: new TextStyle(fontSize: 32.0))
        );
    }
}

class ChangePersonName extends StatelessWidget {
  const ChangePersonName({Key key}) : super(key:key);
  @override
  Widget build(BuildContext context) {
    return RaisedButton (
      child: Text('Change Person Name'),
      onPressed: () {
        context.read<Person>().changeName();
      },
    );
  }
}

class ChangePersonAge extends StatelessWidget {
  const ChangePersonAge({Key key}) : super (key:key);
  @override
  Widget build(BuildContext context) {
    return RaisedButton (
      child: Text('Change Person Age'),
      onPressed: () {
        context.read<Person>().changeAge();
      },
    );
  }
}

 

provider:

读数据(两种): 

// select 方式,绑定对象里面的属性,重绘少,性能高
final personAge = context.select((Person p)=>p.age);
new Text('Person Age: ${personAge}', style: new TextStyle(fontSize: 32.0));

// 绑定对象, 重绘相对多, 性能相对低
new Text('Person Age: ${context.watch<Person>().age}', style: new TextStyle(fontSize: 32.0))

  

写数据:

RaisedButton (
      child: Text('Change Person Age'),
      onPressed: () {
        context.read<Person>().changeAge();
      },
    );

 

分享到:
评论

相关推荐

    Android5.0 Settings源码

    5. **providers**:这部分涉及到ContentProvider,例如`DevicePolicyProvider`用于管理设备策略,`SettingsProvider`则处理系统设置的读写。 6. **xml**:这个目录下的XML文件通常用来定义首选项(Preferences)...

    Android5.0 Contacts联系人源码

    Android 5.0引入了权限管理系统,联系人应用需要获取`READ_CONTACTS`和`WRITE_CONTACTS`权限才能读写联系人。同时,系统还支持与其他数据源(如Google账户)同步联系人。`SyncAdapter`负责定期执行同步任务,确保...

    Android 5.0拨号盘 Dialer源码

    `com.android.providers.contacts.ContactsProvider2`是Android 5.0中的联系人ContentProvider,Dialer通过它获取和操作联系人信息。 6. **BroadcastReceiver**:Dialer使用BroadcastReceiver监听系统广播事件,...

    get_it:Get It-简单的直接服务定位器,可将接口与具体实现分离,并从App的任何位置访问具体实现。 维护者

    从Flutter视图访问视图/ AppModels /管理器/ BLoC V5.0有一些重大更改。请检查发行说明以了解新功能。 用V4.0.0打破更改已重新考虑和改进了有关如何同步已注册实例创建的原理 :grinning_face_with_big_eyes: 。 请...

    2023年全国大学生英语竞赛样题(C类)样题答案及听力原文.pdf

    2023年全国大学生英语竞赛样题(C类)样题答案及听力原文

    出纳考核表.xls

    出纳考核表

    基于多种天气因素的光伏电站太阳能辐射量预测系统-采用人工神经网络与离线优化算法,MATLAB代码:考虑多种天气条件下光伏电站太阳能辐射量预测 关键词:辐射量预测 光伏预测 多种天气因素 参考文档:

    基于多种天气因素的光伏电站太阳能辐射量预测系统——采用人工神经网络与离线优化算法,MATLAB代码:考虑多种天气条件下光伏电站太阳能辐射量预测 关键词:辐射量预测 光伏预测 多种天气因素 参考文档:《Solar Radiation Prediction and Energy Allocation for Energy Harvesting Base Stations》 仿真平台:MATLAB+CPLEX 平台 优势:代码具有一定的深度和创新性,注释清晰,非烂大街的代码,非常精品 主要内容:代码主要做的是如何利用预测光伏电站太阳能辐射量的问题,利用人工神经网络对对其内太阳辐射量进行预测,并对无云天气以及多云天气进行了分别讨论,与线性模型相比该模型具有更好的性能,除此之外,代码还研究了太阳能的分配问题,采用离线优化算法和四种在线启发式算法分别进行分配策略的优化,并利用太阳辐射数据评估了算法的性能。 该代码适合新手学习以及在此基础上进行拓展,代码质量非常高,出图效果极佳 ,核心关键词: 1. 光伏电站太阳能辐射量预测 2. 多种天气因素 3. 人工神经网络 4. 预测模型 5. 线性

    数据结构实验实习指导书(c语言)

    数据结构实验实习指导书(c语言)

    游戏 生存小游戏.exe

    "lyh不会打代码"生存小有戏改版

    站群系统/泛目录站群源码/泛站群cms系统【小说泛目录站群源码】

    站群系统/泛目录站群源码/泛站群cms系统【小说泛目录站群源码】 效果截图和演示https://www.lxsjfx.cn/3181.html 绿茶小说站群2.x-秒收隔天速出权重-小说流量稳定收割机-精品轻量级PHP站群系统站群系统,小说行业专用引流精品站群,绿茶小说站群为独立站群系统(无需依托CMS),独立的整篇小说优化内容库(拒绝句子拼凑),模板自适应PC端和移动端,流量一起做! 1、绿茶小说站群为独立站群系统(无需依托CMS) 2、对域名要求不高,百元域名均可操作 3、独立的首页、列表页、小说阅读页 4、独立的整篇小说优化内容库(拒绝句子拼凑) 5、可自定页面后缀(html、shtml、xml…..) 6、拒绝全站404跳转到内容页 7、还有强大的网站XML地图功能,便于链接提交 8、模板自适应PC端和移动端,流量一起做! 站群系统/泛目录站群源码/泛站群cms系统【小说泛目录站群源码】

    IQC检验员(来料检验员)绩效考核表.xls

    IQC检验员(来料检验员)绩效考核表

    2024年全球AI应用趋势年度报告

    2024年全球AI应用趋势年度报告

    安全生产绩效考核表.doc

    安全生产绩效考核表

    04-【标准制度】公司 KPI 绩效考核流程.docx

    04-【标准制度】公司 KPI 绩效考核流程

    第14讲:深入理解指针(4).pdf

    第14讲:深入理解指针(4)

    考虑用户舒适度的冷热电多能互补综合能源系统优化调度模型:结合PMV衡量与碳排放交易机制的MATLAB仿真实现,考虑用户舒适度的冷热电多能互补综合能源系统优化调度 MATLAB代码:考虑用户舒适度的冷热

    考虑用户舒适度的冷热电多能互补综合能源系统优化调度模型:结合PMV衡量与碳排放交易机制的MATLAB仿真实现,考虑用户舒适度的冷热电多能互补综合能源系统优化调度 MATLAB代码:考虑用户舒适度的冷热电多能互补综合能源系统优化调度 关键词:用户舒适度 综合能源 PMV 优化调度 参考文档:《冷热电气多能互补的微能源网鲁棒优化调度》基础模型加舒适度部分模型; 仿真平台:MATLAB+yalmip+cplex 主要内容:代码主要做的是考虑用户舒适度的冷热电多能互补综合能源系统优化调度模型,在传统的冷热电联供型综合能源系统的基础上,进一步考虑了热惯性以及用户的舒适度,并用预测平均投票数PMV对用户的舒适度进行衡量,且通过改变PMV的数值,可以对比不同舒适度要求对于综合能源系统调度结果的影响。 同时,代码还补充性的考虑了碳排放交易机制,并设置经济性最优以及碳排放最优两种对比场景,从而丰富算例,效果非常明显。 使用matlab+yalmip+cplex进行代码的 ,考虑用户舒适度; 综合能源系统; PMV; 优化调度; 冷热电多能互补; 碳排放交易机制。,考虑用户舒适度与碳排放交易的冷热电多能

    基于ANSI转义码在Xshell脚本中的光标操作与应用实例:进度条制作详解

    内容概要:本文详细阐述了利用ANSI转义码在Xshell脚本中进行光标的灵活操控方法。介绍了从光标的隐藏、定位(特定行/列)、保存位置、复位、清除以及显示控制的基本命令,重点描述了如何使用以上提到的功能构建实用的UI组件——文本模式下工作的进度条。文中提供的简单实例演示了一个完整的循环逻辑,它能动态刷新视图,在每一次迭代中根据程序实际进展更新屏幕上的表现形式,同时保持界面美观性和易读性。并且提到由于不同的终端可能有不同的兼容情况,脚本的跨环境行为可能存在细微差别。 适合人群:初学者至中级水平的技术爱好者或者软件开发者,尤其是希望深入掌握Linux环境下命令行工具使用者。 使用场景及目标:① 学习并理解Xshell脚本里涉及的ANSI转义码概念和技术点,从而增强对终端界面元素(如菜单、提示符等)的操作技能;② 掌握通过程序手段构造动态变化的CLI应用程序技巧,比如实时跟踪长时间任务的状态; 阅读建议:本文不仅包含了具体命令的学习,更展示了它们是如何组合起来创造复杂视觉反馈机制的案例研究。对于想进一步探索终端开发领域的程序员而言,这无疑提供了很好的入门指引材料。考虑到各种操作系统上支持度的问题,在测试代码之前应当确认自己的工作平台已经正确配置好。

    达梦数据库优化指南:涵盖回表问题、性能调优、SQL执行计划优化技术详解及应用场景

    内容概要:该文档详细探讨了针对达梦数据库的各种性能优化技术和处理方法。具体包括回表问题及其解决措施如覆盖索引和FAST POOL机制;变量窥探、统计数据收集优化方法,例如设置统计桶数量和采样子表数目;视图上拉、JOIN优化、EXISTS与NOT EXISTS子查询重写策略;分区裁剪和多KEY哈希等方面的深入探讨,提供了多个具体的优化技巧,旨在帮助用户有效提升SQL执行性能,并解决了多种可能导致性能下降的关键因素。 适合人群:数据库管理员、运维工程师及具有一定经验的数据开发人员等,尤其是负责使用和维护基于达梦数据库系统的技术团队成员。 使用场景及目标:适用于希望通过改善查询速度来提高系统响应时间的专业人士;需要处理大型数据库或复杂查询的任务;或是正在寻找改进现有数据库架构的方法的机构。它还特别针对那些希望确保最优硬件资源利用率的人群。 其他说明:本文档不仅介绍了理论性的背景知识和技术细节,还包括了大量的实际案例演示和参数调整建议,方便读者理解和实践这些优化方法。此外,针对每种优化策略提供了详细的指导,使得即使是对某些高级特性较为陌生的读者也能顺利掌握关键技能。

    54 -营销部经理绩效考核表1.xlsx

    54 -营销部经理绩效考核表1

Global site tag (gtag.js) - Google Analytics