zl程序教程

您现在的位置是:首页 >  移动开发

当前栏目

Flutter 在生命周期里 使用观察者 监听键盘展开、关闭 或者 其他操作

flutter 操作 关闭 监听 其他 或者 生命周期 键盘
2023-09-27 14:28:53 时间

Flutter 在生命周期里 使用观察者 监听键盘展开、关闭 或者 其他操作
我这里的代码是 收起键盘时 关掉输入框的焦点

首先 with WidgetsBindingObserve
1.在初始化时 添加观察者 WidgetsBinding.instance.addObserver(this);

  @override
  void initState() {
      //  implement initState
      super.initState();
      WidgetsBinding.instance.addObserver(this); //添加观察者
	}

2.进行监听 WidgetsBinding.instance.addPostFrameCallback

 ///应用尺寸改变时回调,例如旋转、键盘弹出、收缩 
  @override
  void didChangeMetrics() {
    super.didChangeMetrics();
    WidgetsBinding.instance.addPostFrameCallback((_) {
      /// 键盘收起时 
      if(MediaQuery.of(context).viewInsets.bottom==0){
        //关闭键盘焦点
        _focusNodeUser.unfocus();
      }
    });
  }

3.页面关闭时 提前销毁 观察者

@override
  void dispose() {
    //销毁观察者
    WidgetsBinding.instance.removeObserver(this);
    // TODO: implement dispose
    super.dispose();
```}