1

我有一个对话框,用户点击发送按钮后出现。当对话框出现时,我想在 5 秒后显示一个文本。我使用Future.delayed但文本根本没有出现。只有当我关闭对话框并再次打开它时才会出现。我想在打开对话框 5 秒后显示文本。

这是我的功能

  void _initialize() {
    Future<void>.delayed(const Duration(seconds: 3), () {
      if (mounted) {
        setState(() {
          visibility = true;
        });
      }
    });
  }
}

这是我在按钮的 onTab 中的对话框代码

_initialize()
 showDialog(context: context,
        barrierDismissible: false,

        builder: (BuildContext contextd){

          return  WillPopScope(

            onWillPop: () {return Future.value(false);},
            child: Dialog(
              shape: RoundedRectangleBorder(
                  borderRadius: BorderRadius.circular(10)
              ),
              child: Padding(
                padding: EdgeInsets.fromLTRB(20.w, 20.h, 20.w, 20.h),
                child: Column(
                        children: [
                       //here are some widgets
                      Visibility(
                        visible:visibility?true:false,
                        child: Text("Resend?",style: TextStyle(decoration: 
                              TextDecoration.underline,),)),
               ],),
              ),
            ),
          );

        });
4

3 回答 3

2

发生这种情况是因为您setState的更新visibility具有与构建器对话框不同的上下文。Visibility实际上是更新但仅在关闭并再次打开时出现在对话框中,因为这是更新构建对话框的方式。如果您想使用上下文对话框需要使用该小部件:

StatefulBuilder(
      builder: (context, setState) {

进入您的对话框,然后调用setState.

于 2022-01-17T08:57:34.170 回答
1

尝试StatefulBuilder像这样使用:

showDialog(
        context: context,
        builder: (BuildContext context) => StatefulBuilder(
          builder: (context, setState) {
            return //somthing to return;
          },
        ));
  
于 2022-01-17T08:48:27.730 回答
1

尝试使用StatefulBuilder. 使用bool visibleandsetDialogState参数,您可以更新对话框内容的状态。

showDialog(
  context: context,
  barrierDismissible: false,
  builder: (BuildContext context) {
    return StatefulBuilder(
      builder(context, setDialogState) {
        // this variable is used for the conditional display
        bool visible = false;
        // this future will update the visible variable in 3 seconds, after the dialog is displayed already
        Future.delayed(Duration(seconds: 3)).then(() => setDialogState(() { visible = true;}));
        return WillPopScope(
          onWillPop: () { return Future.value(false); },
          child: Dialog(
            shape: RoundedRectangleBorder(
              borderRadius: BorderRadius.circular(10)
              ),
            child: Padding(
              padding: EdgeInsets.fromLTRB(20.w, 20.h, 20.w, 20.h),
              child: Column(
                children: [
                  //here are some widgets
                  Visibility(
                    visible:visible,
                    child: Text(
                      "Resend?",
                      style: TextStyle(
                        decoration: TextDecoration.underline,
                        ),
                      ),
                    ),
                  ],
                  ),
              ),
            ),
          );
      },
      );
};
于 2022-01-17T08:54:32.220 回答