如何检测用户已停止在 TextField 中输入?

Vic*_*khe 6 delay textfield dart flutter

我正在使用TextField哪个onChanged函数

我正在调用我的代码,但现在的问题是每次输入或删除新单词时都会执行代码。

我正在寻找的是如何识别用户何时停止打字

意味着添加一些延迟或类似的东西。

我也尝试添加delayusingFuture.delayed函数,但该函数也被执行了 n 次。

TextField(
   controller: textController,
   onChanged: (val) {
            if (textController.text.length > 3) {
              Future.delayed(Duration(milliseconds: 450), () {
                 //code here
              });
            }
            setState(() {});
          },
 )
Run Code Online (Sandbox Code Playgroud)

Vic*_*khe 2

感谢@pskink

我能够实现我正在寻找的功能。

将stream_transform包导入到​​你的pubspec.yaml

stream_transform: ^0.0.19

import 'package:stream_transform/stream_transform.dart';

StreamController<String> streamController = StreamController();

@override
void initState() {
  streamController.stream
    .transform(debounce(Duration(milliseconds: 400)))
    .listen((s) => _validateValues());

  super.initState();
}

//function I am using to perform some logic
_validateValues() {
  if (textController.text.length > 3) {
     // code here
  }else{
     // some other code here
  }
}
Run Code Online (Sandbox Code Playgroud)

文本字段代码

TextField(
   controller: textController,
   onChanged: (val) {
        streamController.add(val);
     },
)
Run Code Online (Sandbox Code Playgroud)

  • 这里的去抖功能是什么意思?它没有被定义。@VickySalunkhe (2认同)