首页 前端设计 Flutter 正文内容

flutter事件拦截的简单介绍

钟逸 Flutter 2024-04-06 04:28:07 13

一文解决Flutter中使用TextField遇到的各种疑难杂症

1、一种是使用系统的返回键,比如 android 底部导航自带的返回,另一种是使用导航栏自定义的返回键 第一种情况需要在页面根布局使用 WillPopScope 在 onWillPop 中拦截返回处理。

2、对于金额等的输入,常常要求TextField限制输入为小数,可使用以下约束:但这种限制会有问题,比如可以输入 0.1 这种其实就不是小数了,并且不能限制小数点的输入位数。

3、GestureDetector的 behavior 有三个类型 默认是deferToChild,只有当children可以接收点击事件才能响应点击。

4、TextField样式自带下划线背景,在decoration中设置border: InputBorder.none即可去掉。

5、也就是Widget会被重建,重建时原有的状态不会自动恢复,里面的文字自然就消失了,解决方法是把flutterlistviewitem封装成一个StatefulWidget,然后用AutomaticKeepAliveClientMixin来保证TextField不会被回收。

flutter跳转原生页面后的穿透问题

1、原因推测:推测是flutter对控制器(或者view)加了分类,重写了控制器的点击事件,用来计算是否在对应的点击位置有flutter响应事件。没有的话再扔出去点击事件。

2、使用GestureTap 包装组件的时候,子组件使用Expand,点击Expand上有时候不会触发点击事件,这时候在用Container 包装一下,color 设置为 Colors.transparent ,子组件的事件就可以穿透了到父组件了。

3、一种是使用系统的返回键,比如 android 底部导航自带的返回,另一种是使用导航栏自定义的返回键 第一种情况需要在页面根布局使用 WillPopScope 在 onWillPop 中拦截返回处理。

4、注释 :Flutter Incorrect use of ParentDataWidget 问题原因:Expanded、Flexible等组件,在“Container、Padding、Stack”组件中导致的。解决方案:保持: Expanded、Flexible 只在 Row、Column 等组件内,不在其他组件内使用。

Flutter开发-屏蔽Widget的多点触控行为

1、另外,还可以使一个Widget能够在不强迫其子部件也构建的情况下进行重新构建。 在Widget的实例保持不变时;Flutter会有意识的不去重建子部件。这意味着我们可以缓存Widget树的某些部分,以防止不必要的重新构建。

2、设置百分比的因子: widthFactor 1即100%。

3、当widget的状态发生变化时,widget会重新构建UI,Flutter会对比前后变化的不同, 以确定底层渲染树从一个状态转换到下一个状态所需的最小更改。Text : 该 widget 可让创建一个带格式的文本。

Flutter事件穿透

https://github.com/flutter/flutter/issues/35784 原因推测:推测是flutter对控制器(或者view)加了分类,重写了控制器的点击事件,用来计算是否在对应的点击位置有flutter响应事件。没有的话再扔出去点击事件。

使用GestureTap 包装组件的时候,子组件使用Expand,点击Expand上有时候不会触发点击事件,这时候在用Container 包装一下,color 设置为 Colors.transparent ,子组件的事件就可以穿透了到父组件了。

用 Listener的onPointerDown 包裹一下,就可以透传点击事件了。

这里主要讲解 GetxController 的事件监听,包括监听 单个值 、 多个值 等。

文章目录
    搜索