MVVM即 Model-View-ViewModel的缩写。
dependencies:
flutter:
sdk: flutter
provider: ^6.0.3
dio: ^4.0.6
新建dio_utils.dart文件:
dynamic post(String url, Map map) async {
dynamic result = "";
try {
Response response = await Dio().post(url, queryParameters: map);
result = response.data;
} on DioError catch (e) {
if (e.response != null) {
result = "请求失败 ${e.response!.statusCode}";
} else {
result = "请求失败";
}
}
return result.toString();
}
新建login_model.dart文件:
class LoginModel {
dynamic login(Map map) async {
return await post("https://www.wanandroid.com/user/login", map);
}
}
import 'package:flutter/cupertino.dart';
import 'package:mvvm_flutter/model/login_model.dart';
class LoginViewModel extends ChangeNotifier {
final LoginModel _loginModel = LoginModel();
final TextEditingController _usernameController = TextEditingController();
final TextEditingController _passwordController = TextEditingController();
dynamic _result = "";
TextEditingController get usernameController {
return _usernameController;
}
TextEditingController get passwordController {
return _passwordController;
}
dynamic get result {
return _result;
}
setResult(dynamic data) {
_result = data;
notifyListeners();
}
login() async {
dynamic result = await _loginModel.login({
"username": _usernameController.text,
"password": _passwordController.text,
});
print(result.toString());
setResult(result.toString());
}
@override
void dispose() {
_usernameController.dispose();
_passwordController.dispose();
super.dispose();
}
}
class LoginView extends StatefulWidget {
const LoginView({Key? key}) : super(key: key);
@override
State createState() {
return _LoginViewState();
}
}
class _LoginViewState extends State {
late LoginViewModel loginViewModel;
@override
void dispose() {
loginViewModel.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
loginViewModel = Provider.of(context);
return Scaffold(
appBar: AppBar(
title: const Text("MVVM学习"),
),
body: Center(
child: Column(
children: [
const Text("登陆功能"),
TextField(
controller: loginViewModel.usernameController,
decoration: const InputDecoration(
labelText: "用户名",
prefixIcon: Icon(Icons.supervised_user_circle),
),
),
TextField(
controller: loginViewModel.passwordController,
decoration: const InputDecoration(
labelText: "密码",
prefixIcon: Icon(Icons.verified_user),
),
obscureText: true,
),
OutlinedButton(
onPressed: () {
loginViewModel.setResult("");
loginViewModel.login();
},
child: const Text("登陆"),
),
Text(loginViewModel.result),
],
),
),
);
}
}
void main() {
runApp(
MultiProvider(
providers: [
ChangeNotifierProvider(create: (context) => LoginViewModel()),
],
child: const MyApp(),
),
);
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter MVVM学习',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const LoginView(),
);
}
}