加群452892873 下载对应34课文件,运行方法,建好项目,直接替换lib目录

以下列出的是本课涉及的文件。

RegisterFirst.dart

import 'package:flutter/material.dart';
import 'package:flutter_jdshop/services/ScreenAdapter.dart';
import 'package:flutter_jdshop/widget/JdButton.dart';
import 'package:flutter_jdshop/widget/JdText.dart';
import '../config/Config.dart';
import 'package:dio/dio.dart';
import 'package:fluttertoast/fluttertoast.dart';
class RegisterFirstPage extends StatefulWidget {
RegisterFirstPage({Key key}) : super(key: key); _RegisterFirstPageState createState() => _RegisterFirstPageState();
} class _RegisterFirstPageState extends State<RegisterFirstPage> {
String tel; sendCode() async{
RegExp reg=new RegExp(r"^1\d{10}$");
if(reg.hasMatch(this.tel)){
print("正确");
var api='${Config.domain}api/sendCode';
var responses=await Dio().post(api,data:{"tel":this.tel});
if(responses.data["success"]){
print(responses); //演示期间服务器直接返回给手机发送的验证码
Navigator.pushNamed(context, '/RegisterSecond',arguments: {
"tel":this.tel
}); }else{
Fluttertoast.showToast(
msg: "${responses.data["message"]}",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.CENTER,
);
}
}else{
Fluttertoast.showToast(
msg: "手机号格式不对",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.CENTER,
);
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('用户注册-第一步'),
),
body: Container(
padding: EdgeInsets.all(ScreenAdapter.width()),
child: ListView(
children: <Widget>[
SizedBox(height: ),
JdText(
text: "请输入手机号",
// password: true,
onChanged: (value) {
this.tel=value;
// print(value);
},
),
SizedBox(height: ),
JdButton(
text: "下一步",
color: Colors.red,
cb:sendCode
)
],
),
),
);
}
}

RegisterSecond.dart

import 'package:dio/dio.dart';
import 'package:flutter/material.dart';
import 'package:flutter_jdshop/config/Config.dart';
import 'package:flutter_jdshop/services/ScreenAdapter.dart';
import 'package:flutter_jdshop/widget/JdButton.dart';
import 'package:flutter_jdshop/widget/JdText.dart';
import 'dart:async'; import 'package:fluttertoast/fluttertoast.dart'; class RegisterSecondPage extends StatefulWidget {
Map arguments;
RegisterSecondPage({Key key, this.arguments}) : super(key: key); _RegisterSecondPageState createState() => _RegisterSecondPageState();
} class _RegisterSecondPageState extends State<RegisterSecondPage> {
String tel;
bool sendCodeBtn = false;
int seconds = ;
String code;
@override
void initState() {
super.initState();
this.tel = widget.arguments["tel"];
this._showTimer();
} //
_showTimer() {
print("执行倒计时");
print(this.sendCodeBtn);
Timer t;
t = Timer.periodic(Duration(microseconds: ), (timer) {
setState(() {
this.seconds--;
});
if (this.seconds == ) {
t.cancel(); //清除定时器:
setState(() {
this.sendCodeBtn = true;
});
}
});
} //重新发送验证码:
sendCode() async {
setState(() {
this.sendCodeBtn = false;
this.seconds = ;
this._showTimer();
});
var api = '${Config.domain}api/sendCode';
var responses = await Dio().post(api, data: {"tel": this.tel});
if (responses.data["success"]) {
print(responses); //演示期间服务器直接返回给手机发送的验证码
print(this.sendCodeBtn);
} else {
Fluttertoast.showToast(
msg: "${responses.data["message"]}",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.CENTER,
);
}
} validateCode() async {
var api = '${Config.domain}api/validateCode';
var responses =
await Dio().post(api, data: {"tel": this.tel, "code": this.code});
if (responses.data["success"]) {
print(responses);
Navigator.pushNamed(context, '/RegisterThird');
} else {
Fluttertoast.showToast(
msg: "${responses.data["message"]}",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.CENTER,
);
}
} @override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('用户注册-第二步'),
),
body: Container(
padding: EdgeInsets.all(ScreenAdapter.width()),
child: ListView(
children: <Widget>[
Container(
margin: EdgeInsets.all(),
child: Text("请输入${this.tel}手机收到的验证码"),
),
Stack(
children: <Widget>[
JdText(
text: "请输入验证码",
// password: true,
onChanged: (value) {
print(value);
this.code = value;
},
),
Positioned(
right: ,
top: ,
child: this.sendCodeBtn? RaisedButton(
child: Text("重新${this.sendCodeBtn}发送"),
onPressed: this.sendCode,
): RaisedButton(
child: Text('${this.seconds}秒后重发'),
onPressed: () {},
),
)
],
),
SizedBox(height: ),
JdButton(
text: "下一步",
color: Colors.red,
cb: validateCode,
)
],
),
),
);
}
}
import 'package:dio/dio.dart';
import 'package:flutter/material.dart';
import 'package:flutter_jdshop/config/Config.dart';
import 'package:flutter_jdshop/services/ScreenAdapter.dart';
import 'package:flutter_jdshop/widget/JdButton.dart';
import 'package:flutter_jdshop/widget/JdText.dart';
import 'dart:async'; import 'package:fluttertoast/fluttertoast.dart'; class RegisterSecondPage extends StatefulWidget {
Map arguments;
RegisterSecondPage({Key key, this.arguments}) : super(key: key); _RegisterSecondPageState createState() => _RegisterSecondPageState();
} class _RegisterSecondPageState extends State<RegisterSecondPage> {
String tel;
bool sendCodeBtn = false;
int seconds = ;
String code;
@override
void initState() {
super.initState();
this.tel = widget.arguments["tel"];
this._showTimer();
} //
_showTimer() {
print("执行倒计时");
print(this.sendCodeBtn);
Timer t;
t = Timer.periodic(Duration(microseconds: ), (timer) {
setState(() {
this.seconds--;
});
if (this.seconds == ) {
t.cancel(); //清除定时器:
setState(() {
this.sendCodeBtn = true;
});
}
});
} //重新发送验证码:
sendCode() async {
setState(() {
this.sendCodeBtn = false;
this.seconds = ;
this._showTimer();
});
var api = '${Config.domain}api/sendCode';
var responses = await Dio().post(api, data: {"tel": this.tel});
if (responses.data["success"]) {
print(responses); //演示期间服务器直接返回给手机发送的验证码
print(this.sendCodeBtn);
} else {
Fluttertoast.showToast(
msg: "${responses.data["message"]}",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.CENTER,
);
}
} validateCode() async {
var api = '${Config.domain}api/validateCode';
var responses =
await Dio().post(api, data: {"tel": this.tel, "code": this.code});
if (responses.data["success"]) {
print(responses);
Navigator.pushNamed(context, '/RegisterThird');
} else {
Fluttertoast.showToast(
msg: "${responses.data["message"]}",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.CENTER,
);
}
} @override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('用户注册-第二步'),
),
body: Container(
padding: EdgeInsets.all(ScreenAdapter.width()),
child: ListView(
children: <Widget>[
Container(
margin: EdgeInsets.all(),
child: Text("请输入${this.tel}手机收到的验证码"),
),
Stack(
children: <Widget>[
JdText(
text: "请输入验证码",
// password: true,
onChanged: (value) {
print(value);
this.code = value;
},
),
Positioned(
right: ,
top: ,
child: this.sendCodeBtn? RaisedButton(
child: Text("重新${this.sendCodeBtn}发送"),
onPressed: this.sendCode,
): RaisedButton(
child: Text('${this.seconds}秒后重发'),
onPressed: () {},
),
)
],
),
SizedBox(height: ),
JdButton(
text: "下一步",
color: Colors.red,
cb: validateCode,
)
],
),
),
);
}
}

router.dart

import 'package:flutter/material.dart';
import 'package:flutter_jdshop/pages/Login.dart';
import 'package:flutter_jdshop/pages/RegisterFirst.dart';
import 'package:flutter_jdshop/pages/RegisterSecond.dart';
import 'package:flutter_jdshop/pages/RegisterThird.dart';
import 'package:flutter_jdshop/pages/tabs/Cart.dart';
import '../pages/tabs/Tabs.dart'; import '../pages/Search.dart'; import '../pages/ProductList.dart'; import '../pages/ProductContent.dart'; //配置路由
final routes = {
'/': (context) => Tabs(),
'/login': (context) => LoginPage(),
'/RegisterFirst': (context) =>RegisterFirstPage(),
'/RegisterSecond': (context,{arguments}) =>RegisterSecondPage(arguments:arguments),
'/RegisterThird': (context) =>RegisterThirdPage(),
'/search': (context) => SearchPage(),
'/cart': (context) => CartPage(),
'/productList': (context,{arguments}) => ProductListPage(arguments:arguments),
'/productContent': (context,{arguments}) => ProductContentPage(arguments:arguments),
}; //固定写法
var onGenerateRoute = (RouteSettings settings) {
// 统一处理
final String name = settings.name;
final Function pageContentBuilder = routes[name];
if (pageContentBuilder != null) {
if (settings.arguments != null) {
final Route route = MaterialPageRoute(
builder: (context) =>
pageContentBuilder(context, arguments: settings.arguments));
return route;
} else {
final Route route =
MaterialPageRoute(builder: (context) => pageContentBuilder(context));
return route;
}
}
};

34 Flutter仿京东商城项目 用户注册 注册流程 POST发送验证码 倒计时功能 验证验证码的更多相关文章

  1. 16 Flutter仿京东商城项目 跳转到搜索页面实现搜索功能 以及搜索筛选

    ProductList.dart import 'package:flutter/material.dart'; import '../services/ScreenAdaper.dart'; imp ...

  2. 01-02 Flutter仿京东商城项目 功能分析、底部导航Tab切换以及路由配置、架构搭建:(Flutter仿京东商城项目 首页布局以及不同终端屏幕适配方案)

    Flutter和Dart交流学习群:交流群:452892873 01Flutter仿京东商城项目 功能分析.底部导航Tab切换以及路由配置.架构搭建 02Flutter仿京东商城项目 首页布局以及不同 ...

  3. 36 Flutter仿京东商城项目 用户登录 退出登录 事件广播更新状态

    Login.dart import 'dart:convert'; import 'package:dio/dio.dart'; import 'package:flutter/material.da ...

  4. 33Flutter仿京东商城项目 登录 注册相关页面布局

    加群452892873 下载对应33课文件,运行方法,建好项目,直接替换lib目录 以下列出的是本课涉及的文件. User.dart import 'package:flutter/material. ...

  5. 37 Flutter仿京东商城项目 结算页面布局

    加群452892873 下载对应34课文件,运行方法,建好项目,直接替换lib目录 CheckOut.dart import 'package:flutter/material.dart'; impo ...

  6. 07-08 Flutter仿京东商城项目 商品分类页面布局:Flutter仿京东商城项目 商品分类页面数据渲染

    Flutter实战(交流群:452892873) 本项目是一个实战项目,根据目录建文件,并复制从第一节到最新更新的文章,可以构成完整的一个请求后台数据的项目: CateModel.dart class ...

  7. 42 Flutter仿京东商城项目 修改默认收货地址 显示默认收货地址

    CheckOut.dart import 'package:flutter/material.dart'; import '../services/ScreenAdapter.dart'; impor ...

  8. 41 Flutter 仿京东商城项目签名验证 增加收货地址、显示收货地址 事件广播

    加群452892873 下载对应41课文件,运行方法,建好项目,直接替换lib目录 AddressAdd.dart import 'package:dio/dio.dart'; import 'pac ...

  9. 39 Flutter仿京东商城项目 收货地址列表、增加 修改收货地址布局、弹出省市区选择器

    加群452892873 下载对应39课文件,运行方法,建好项目,直接替换lib目录 pubspec.yaml city_pickers: ^ AddressAdd.dart import 'packa ...

随机推荐

  1. RT-Thread--线程间通信

    线程中通信 在裸机编程中,经常会使用全局变量进行功能间的通信,如某些功能可能由于一些操作而改变全局变量的值,另一个功能对此全局变量进行读取,根据读取到的全局变量值执行相应的动作,达到通信协作的目的: ...

  2. ubuntu---记录.动态库默认路径的踩坑

    发现这个问题,还是经过一个报错问题卡了好多天,然后请求好多人的支援,最后个人的疑问:为什么明明指明了路径,生成 .SO 没有问题,在调用.SO 就有问题,报错各种找不到函数或者未定义,然后把缺的 *. ...

  3. sql网址

    w3school版 https://www.w3school.com.cn/sql/index.asp 菜鸟教程版 https://www.runoob.com/sql/sql-tutorial.ht ...

  4. HDU-5728-PowMod-求phi(i*n)前缀和+指数循环节

    HDU-5728-PowMod-求phi(i*n)前缀和+指数循环节 [Problem Description] 令\(k=\sum_{i=1}^m \varphi(i\cdot n)\ mod \ ...

  5. MySQL进阶14--标识列(自增序列/auto_increment)--设置/展示步长--设置/删除标示列

    /*进阶14 标识列 又称为自增序列; 含义 : 可以不用手动的插入值, 系统提供默认的序列值(1-->n) 特点 : 1.标识列必须和主键搭配? 不一定,但要求是一个key 2.一个表可以有几 ...

  6. subline html5的快捷键

    选择类 Ctrl+D 选中光标所占的文本,继续操作则会选中下一个相同的文本. Alt+F3 选中文本按下快捷键,即可一次性选择全部的相同文本进行同时编辑.举个栗子:快速选中并更改所有相同的变量名.函数 ...

  7. 进击web与web协议

    我一直比较抵制web,web的各种协议以及后端与前端的交互,慢慢的发现除了数据和算法其实计算机软件方面还有另一块高地,那就是web协议. 十分感谢极客时间提供了性价比极高的课程,让我遇到了这么好的老师 ...

  8. QPainter 提高绘制效率的方法

    原文: https://my.oschina.net/u/3919756/blog/1944747 如果我们用painter一个一个的绘制直线,圆等在控件上,绘制效率会不高.为了提高效率,我们可以设置 ...

  9. 入门: 在Windows上搭建Flutter开发环境

    使用镜像 由于在国内访问Flutter有时可能会受到限制,Flutter官方为中国开发者搭建了临时镜像,大家可以将如下环境变量加入到用户环境变量中: export PUB_HOSTED_URL=htt ...

  10. Java图形界面

    图形界面 JFrame在swingbao JFrame jframe = new JFrame(); iframe.setVisible(true); //设置窗口显示 jframe.setLocat ...