Flutter 实现返回上一页清空编辑框文本

datetime,

emailAddress,

url,

password

}

class BindCardTextFiled extends StatefulWidget {

final ITextInputType keyboardType;

final int maxLines;

final int maxLength;

final String hintText;

final TextStyle hintStyle;

final ITextFieldCallBack fieldCallBack;

final Icon deleteIcon;

final InputBorder inputBorder;

final Widget prefixIcon;

final TextStyle textStyle;

final FormFieldValidator validator;

final TextAlign textAlignP;

final String inputText;

BindCardTextFiled({

Key key,

ITextInputType keyboardType: ITextInputType.text,

this.maxLines = 1,

this.maxLength,

this.hintText,

this.hintStyle,

this.fieldCallBack,

this.deleteIcon,

this.inputBorder,

this.textStyle,

this.prefixIcon,

this.validator,

this.textAlignP,

this.inputText,

}) : assert(maxLines == null || maxLines > 0),

assert(maxLength == null || maxLength > 0),

keyboardType = maxLines == 1 ? keyboardType : ITextInputType.multiline,

super(key: key);

@override

State createState() {

return _ITextFieldState();

}

}

class _ITextFieldState extends State {

String _inputText = “”;

bool _deleteIcon = false;

bool _isNumber = false;

bool _isPassword = false;

///输入类型

TextInputType _getTextInputType() {

switch (widget.keyboardType) {

case ITextInputType.text:

return TextInputType.text;

case ITextInputType.multiline:

return TextInputType.multiline;

case ITextInputType.number:

_isNumber = true;

return TextInputType.number;

case ITextInputType.phone:

_isNumber = true;

return TextInputType.phone;

case ITextInputType.datetime:

return TextInputType.datetime;

case ITextInputType.emailAddress:

return TextInputType.emailAddress;

case ITextInputType.url:

return TextInputType.url;

case ITextInputType.password:

_isPassword = true;

return TextInputType.text;

}

return TextInputType.text;

}

///输入范围

List _getTextInputFormatter() {

return _isNumber

? [

WhitelistingTextInputFormatter.digitsOnly,

]
null;

}

@override

Widget build(BuildContext context) {

if(widget.inputText==null){

_inputText=“”;

}

TextEditingController _controller = new TextEditingController.fromValue(

TextEditingValue(

text: _inputText,

selection: new TextSelection.fromPosition(TextPosition(

affinity: TextAffinity.downstream,

offset: _inputText.length))));

TextField textField = new TextField(

controller: _controller,

decoration: InputDecoration(

hintStyle: widget.hintStyle,

counterStyle: TextStyle(color: Colors.white),

hintText: widget.hintText,

border: widget.inputBorder != null

? widget.inputBorder
UnderlineInputBorder(),

fillColor: Colors.transparent,

filled: true,

prefixIcon: widget.prefixIcon,

suffixIcon: _deleteIcon

? new Container(

width: 20.0,

height: 20.0,

child: new IconButton(

alignment: Alignment.center,

padding: const EdgeInsets.all(0.0),

iconSize: 18.0,

icon: widget.deleteIcon != null

? widget.deleteIcon
Icon(Icons.cancel),

onPressed: () {

setState(() {

_inputText = “”;

_deleteIcon = (_inputText.isNotEmpty);

widget.fieldCallBack(_inputText);

});

},

),

)
new Text(“”),

),

onChanged: (str) {

setState(() {

_inputText = str;

_deleteIcon = (_inputText.isNotEmpty);

widget.fieldCallBack(_inputText);

});

},

keyboardType: _getTextInputType(),

maxLength: widget.maxLength,

maxLines: widget.maxLines,

inputFormatters: _getTextInputFormatter(),

style: widget.textStyle,

obscureText: _isPassword,

textAlign: widget.textAlignP,

);

return textField;

}

}

首先:首先要对自定义编辑框进行粗略的介绍:

1、自定义编辑框是继承自StatefulWidget,与StatelessWidget的区别在于,参考https://flutterchina.club/widgets-intro/

Flutter中文官网的原话是:

在编写应用程序时,通常会创建新的widget,这些widget是无状态的StatelessWidget或者是有状态的StatefulWidget, 具体的选择取决于您的widget是否需要管理一些状态。widget的主要工作是实现一个build函数,用以构建自身。一个widget通常由一些较低级别widget组成。Flutter框架将依次构建这些widget,直到构建到最底层的子widget时,这些最低层的widget通常为RenderObject,它会计算并描述widget的几何形状。

例如:基础的基础 Widget(Text 、Row、Column、Stack、Container等)在build中实现继承自StatelessWidget。

例如:使用 Material 组件,在build中构建布局,build函数的类可以继承自StatelessWidget

例如:处理手势操作,在build中构建手势操作布局,build函数的类可以继承自StatelessWidget

今天我遇到的问题就是与根据用户输入改变widget有关。

2、每次手动触发,一旦调用就会触发函数build,随便完成了情况文本的操作:

setState(() {

进行文本数据改变操作

});

3、自定义编辑框BindCardTextFiled代码块:

inputText 用来清空文本

fieldCallBack 用来回传文本框变化后最终的值

final ITextFieldCallBack fieldCallBack;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

总结

【Android 详细知识点思维脑图(技能树)】

image

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

的**,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

[外链图片转存中…(img-SFaPBziK-1711817513503)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 20
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值