Flutter 定时器相关

在写JS时,大家都习惯了用setTimeout 和 setInterval 设置定时器。那么在Flutter中也有相关的。

  1. JavaScript setTimeout →\rightarrow → Dart Timer

Javascript

Javascrip 复制代码
setTimeout(() => { 
  console.log("两秒后执行"); 
}, 2000);

Flutter/Dart

Flutter/Dart 复制代码
import 'dart:async'; 
Timer(Duration(seconds: 2), () { 
    print("两秒后执行"); 
});

Flutter/Dart提供了delay的方法而Javascript需要结合Promise实现

Javascript 复制代码
const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));

await delay(2000);
print("在等待两秒后执行");
Flutter/Dart 复制代码
await Future.delayed(Duration(seconds: 2)); 
print("在等待两秒后执行");
  1. JavaScript setInterval →\rightarrow → Dart Timer.periodic 间隔多少时间来执行方法

Javascript

Javascript 复制代码
const intervalId = setInterval(() => { 
    console.log("每隔一秒执行"); 
}, 1000);

//停止执行的方法
clearInterval(intervalId);

Flutter/Dart

Flutter/Dart 复制代码
import 'dart:async'; 

Timer myTimer = Timer.periodic(Duration(seconds: 1), (timer) { 
    print("每隔一秒执行"); 
    //可以在一定的条件下取消执行
    if (someCondition) { 
        timer.cancel();
 }); 
 
 //停止执行的方法
 myTimer.cancel();

注:如果在Flutter statefullWidget中使用的时候 需要在dispose方法里面调用cancel的方法否者将会在后台一直执行

Flutter/Dart 复制代码
class MyTimerWidget extends StatefulWidget { 
    @override _MyTimerWidgetState createState() => _MyTimerWidgetState(); 
} 

class _MyTimerWidgetState extends State<MyTimerWidget> { 
    Timer? _timer; 
    @override 
    void initState() { 
        super.initState(); 
        // 在创建之后开始计时
        _timer = Timer.periodic(Duration(seconds: 1), (timer) { 
            setState(() { 
              // 通过setState更新UI 
            }); 
        }); 
    } 
    @override 
    void dispose() { 
        _timer?.cancel(); 
        // 在这里清楚timer定时器
        super.dispose(); 
    } 
    @override 
    Widget build(BuildContext context) { 
        return Text("Timer is running..."); 
    } 
  }
相关推荐
恋猫de小郭2 天前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
恋猫de小郭2 天前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
程序员老刘4 天前
跨平台开发地图 | 2026年6月
flutter·ai编程·客户端
悟空瞎说5 天前
Flutter 架构详解:新手必懂底层原理
flutter
SoaringHeart5 天前
Flutter最佳实践:IM聊天文字链接自动识别跳转
前端·flutter
恋猫de小郭5 天前
KMP / CMP 鸿蒙版本 Beta 发布,他有什么特别之处?
android·前端·flutter
风华圆舞6 天前
Flutter + 鸿蒙 Intents Kit:页面直达能力的完整接入方案
flutter·ui·华为·harmonyos
韩曙亮6 天前
【Flutter】Flutter 组件 ④ ( 组件渲染 的 三棵树理论 | Widget 树 → Element 树 → RenderObject 树 )
flutter·element·widget·renderobject
恋猫de小郭6 天前
Android 17 正式版发布,全新 AI 和各种破坏性更新
android·前端·flutter
kingbal6 天前
Windows:flutter环境搭建
windows·flutter