温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

flutter中怎么实现发送验证码功能

发布时间:2021-08-12 17:48:19 来源:亿速云 阅读:169 作者:Leah 栏目:编程语言

这期内容当中小编将会给大家带来有关flutter中怎么实现发送验证码功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

一个发送验证码的需求:包括限制文本框输入长度和只允许输入数字

class MyBody extends StatefulWidget { @override _MyBodyState createState() => _MyBodyState();} class _MyBodyState extends State<MyBody> { bool isButtonEnable=true;  //按钮状态 是否可点击 String buttonText='发送验证码'; //初始文本 int count=60;      //初始倒计时时间 Timer timer;      //倒计时的计时器 TextEditingController mController=TextEditingController();  void _buttonClickListen(){ setState(() {  if(isButtonEnable){   //当按钮可点击时  isButtonEnable=false; //按钮状态标记  _initTimer();   return null;   //返回null按钮禁止点击  }else{     //当按钮不可点击时//  debugPrint('false');  return null;    //返回null按钮禁止点击  } }); }   void _initTimer(){ timer = new Timer.periodic(Duration(seconds: 1), (Timer timer) {  count--;  setState(() {  if(count==0){   timer.cancel();    //倒计时结束取消定时器   isButtonEnable=true;  //按钮可点击   count=60;     //重置时间   buttonText='发送验证码';  //重置按钮文本  }else{   buttonText='重新发送($count)'; //更新文本内容  }  }); }); }   @override void dispose() { timer?.cancel();  //销毁计时器 timer=null; super.dispose(); }   @override Widget build(BuildContext context) { return Container(  child: Column(//  mainAxisAlignment: MainAxisAlignment.center,  children: <Widget>[   Container(    color: Colors.white,    padding: EdgeInsets.only(left: 10,right: 10),    child: Row(     mainAxisAlignment: MainAxisAlignment.spaceBetween,//     crossAxisAlignment: CrossAxisAlignment.center,     crossAxisAlignment: CrossAxisAlignment.baseline,     textBaseline: TextBaseline.ideographic,     children: <Widget>[     Text('验证码',style: TextStyle(fontSize: 13,color: Color(0xff333333)),),     Expanded(      child: Padding(padding: EdgeInsets.only(left: 15,right: 15,top: 15),      child: TextFormField(      maxLines: 1,      onSaved: (value) { },      controller: mController,      textAlign: TextAlign.left,      inputFormatters: [WhitelistingTextInputFormatter.digitsOnly,LengthLimitingTextInputFormatter(6)],      decoration: InputDecoration(       hintText: ('填写验证码'),       contentPadding: EdgeInsets.only(top: -5,bottom: 0),       hintStyle: TextStyle(       color: Color(0xff999999),       fontSize: 13,       ),       alignLabelWithHint: true,       border: OutlineInputBorder(borderSide: BorderSide.none),      ),      ),),     ),     Container(      width: 120,      child: FlatButton(      disabledColor: Colors.grey.withOpacity(0.1),  //按钮禁用时的颜色      disabledTextColor: Colors.white,     //按钮禁用时的文本颜色      textColor:isButtonEnable?Colors.white:Colors.black.withOpacity(0.2),       //文本颜色      color: isButtonEnable?Color(0xff44c5fe):Colors.grey.withOpacity(0.1),       //按钮的颜色      splashColor: isButtonEnable?Colors.white.withOpacity(0.1):Colors.transparent,      shape: StadiumBorder(side: BorderSide.none),      onPressed: (){ setState(() {       _buttonClickListen();      });},//      child: Text('重新发送 (${secondSy})'),      child: Text('$buttonText',style: TextStyle(fontSize: 13,),),      ),     ),     ],    ),   ),   Container(   width: double.infinity,   height: 45,   margin: EdgeInsets.only(top: 50,left: 10,right: 10),   child: RaisedButton(    onPressed: () {    debugPrint('${mController.text}');    },    shape: StadiumBorder(side: BorderSide.none),    color: Color(0xff44c5fe),    child: Text(    '下一步',    style: TextStyle(color: Colors.white,fontSize: 15),    ),   ),   ),  ],  ), ); }}

上述就是小编为大家分享的flutter中怎么实现发送验证码功能了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI