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;
final String inputText;
BindCardTextFiled({
…
this.inputText,
this.fieldCallBack,
…
}) : assert(maxLines == null || maxLines > 0),
assert(maxLength == null || maxLength > 0),
keyboardType = maxLines == 1 ? keyboardType : ITextInputType.multiline,
super(key: key);
每次触发setState函数后,去清空编辑框的值
@override
Widget build(BuildContext context) {
…
if(widget.inputText==null){
_inputText=“”;
}
…
}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
最后
希望本文对你有所启发,有任何面试上的建议也欢迎留言分享给大家。
好了,今天的分享就到这里,如果你对在面试中遇到的问题,或者刚毕业及工作几年迷茫不知道该如何准备面试并突破现状提升自己,对于自己的未来还不够了解不知道给如何规划,来看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。
好了~如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言。一定会认真查询,修正不足。谢谢。
为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
何准备面试并突破现状提升自己,对于自己的未来还不够了解不知道给如何规划,来看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。
[外链图片转存中…(img-FkSIsM1F-1713311177869)]
好了~如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言。一定会认真查询,修正不足。谢谢。
[外链图片转存中…(img-y7sGJfTQ-1713311177870)]
为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!