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

Flutter笔记--通知

       这一节回顾一下Flutter中的Notification,Notification(通知)是Flutter中一个重要的机制,在widget树中,每一个节点都可以分发通知,通知会沿着当前节点向上传递,所有父节点都可以通过NotificationListener来监听通知,通过它可以实现跨组件的事件传递,使应用变得更加灵活。

主要步骤包括:

1 创建NotificationListener:在需要监听通知的Widget的build方法中,创建NotificationListener实例。
2 设置onNotification回调函数:NotificationListener需要一个onNotification回调函数,用于处理接收到的通知。在回调函数中,可以编写逻辑来处理不同类型的通知。
3 指定子Widget:将需要被监听通知的Widget作为NotificationListener的子Widget。

栗子:

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';

class NotificationTest extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return _NotificationTest();
  }
}

class _NotificationTest extends State<NotificationTest> {
  int _progress = 0;

  @override
  Widget build(BuildContext context) {
    return Scaffold(body: NotificationListener<ScrollNotification>(
        onNotification: (ScrollNotification notification) {
          if(notification is ScrollStartNotification) {
            print('开始滚动...');
          } else if(notification is ScrollUpdateNotification) {
            final currentPixel = notification.metrics.pixels;
            final totalPixel = notification.metrics.maxScrollExtent;
            double progress = currentPixel / totalPixel;
            setState(() {
              _progress = (progress * 100).toInt();
              print('滚动..._progress:$_progress');
            });
            print('正在滚动: ${currentPixel} - ${totalPixel}');
          } else if(notification is ScrollEndNotification) {
            print('结束滚动...');
          }
           //  返回false表示不阻止事件继续向上冒泡  
           return false;
        },
        child: Stack(
          alignment: Alignment.bottomRight,
          children: [
            ListView.builder(
                itemCount: 100,
                itemExtent: 60,
                itemBuilder: (BuildContext context,int index) {
                  return ListTile(title: Text("Item $index"),);
                })
          ],
        )),);
  }

}

通知冒泡:

1 通知的发起:在Flutter的Widget树中,任何节点都可以分发通知。这通常通过调用Notification.dispatch(context)方法实现,其中context是当前节点的上下文信息。
dispatch方法会调用context.visitAncestorElements(visitAncestor),这个方法会向上遍历父元素,并对每个父元素执行visitAncestor回调。

2 通知的传递:通知从子节点开始,沿着Widget树向上传递,在传递过程中,每个父节点都有机会通过NotificationListener组件来监听这些通知。

3. 通知的中止:通知冒泡可以中止。如果在NotificationListener的onNotification回调中返回true,则表示当前节点已经处理了通知,并决定不再向上传递。如果返回false,则通知会继续向上传递,直到遇到下一个NotificationListener或到达Widget树的顶部。


http://www.kler.cn/news/334383.html

相关文章:

  • 【Unity】双摄像机叠加渲染
  • 使用 Vertex AI Gemini 模型和 Elasticsearch Playground 快速创建 RAG 应用程序
  • 12.1 Linux_进程间通信_管道
  • 开发指南066-平台紧凑版
  • 学生多元智能测评
  • TCP 流量控制 - 滑动窗口和拥塞控制算法解析
  • 大学生就业服务:Spring Boot技术实践
  • 项目管理-信息系统治理
  • rk3568 LTE(EC20 Android14)
  • 一篇文章搞懂Android 刷卡器对接:RS232 DB9串口通讯,通讯设置,刷卡器API介绍;代码示例;MDB协议;
  • 掌握嵌套子查询:复杂 SQL 中 * 列的准确表列关系
  • C/C++/EasyX——入门图形编程(3)
  • javascript:void(0)
  • 【开源免费】基于SpringBoot+Vue.JS美发门店管理系统(JAVA毕业设计)
  • Hadoop-HDFS-core-site.xml,hdfs-site.xml,yarn-site.xml,krb5.conf 都是做什么的?
  • 基金好书入门阅读笔记《基金作战笔记:从投基新手到配置高手的进阶之路》1
  • 面试-2024年9月13号
  • Kafka:架构与核心机制
  • 【BUG】P-tuningv2微调ChatGLM2-6B时所踩的坑
  • 图解C#高级教程(三):泛型