Flutter表单验证插件my_form_validator的使用
Flutter表单验证插件my_form_validator的使用
特性
- 邮箱验证
- 密码验证
- 手机号码验证
- 非空字符串验证
使用方法
在 pubspec.yaml
文件中添加依赖:
dependencies:
my_form_validator:
path: ../my_form_validator
完整示例代码
以下是一个完整的示例,展示了如何使用 my_form_validator
插件进行表单验证。
import 'package:flutter/material.dart';
import 'package:my_form_validator/my_form_validator.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: Text("表单验证示例"),
),
body: Padding(
padding: EdgeInsets.all(16.0),
child: MyForm(),
),
),
);
}
}
class MyForm extends StatefulWidget {
[@override](/user/override)
_MyFormState createState() => _MyFormState();
}
class _MyFormState extends State<MyForm> {
final _formKey = GlobalKey<FormState>();
String _email;
String _password;
void _submit() {
if (_formKey.currentState.validate()) {
_formKey.currentState.save();
Scaffold.of(context).showSnackBar(
SnackBar(content: Text("表单提交成功")),
);
} else {
Scaffold.of(context).showSnackBar(
SnackBar(content: Text("表单验证失败")),
);
}
}
[@override](/user/override)
Widget build(BuildContext context) {
return Form(
key: _formKey,
child: Column(
children: [
TextFormField(
decoration: InputDecoration(labelText: "邮箱"),
validator: (value) {
if (!FormValidator.isEmail(value)) {
return "请输入有效的邮箱地址";
}
return null;
},
onSaved: (value) {
_email = value;
},
),
TextFormField(
decoration: InputDecoration(labelText: "密码"),
obscureText: true,
validator: (value) {
if (!FormValidator.isPassword(value)) {
return "密码至少包含8个字符,包括数字和字母";
}
return null;
},
onSaved: (value) {
_password = value;
},
),
SizedBox(height: 20),
ElevatedButton(
onPressed: _submit,
child: Text("提交"),
)
],
),
);
}
}
更多关于Flutter表单验证插件my_form_validator的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html
1 回复