The Ultimate Hands-on Flutter | And Mvvm - Build ...
首页
手机版
The Ultimate Hands-On Flutter and MVVM - Build ...
热门搜索:
当前位置:电脑软件网络软件下载工具Televzr专业版
The Ultimate Hands-On Flutter and MVVM - Build ...

The Ultimate Hands-on Flutter | And Mvvm - Build ...

  • 大小:707KB
  • 语言:简体中文
  • 类别:下载工具
  • 类型:免费软件
  • 授权:国产软件
  • 时间:2020/07/30
  • 官网:https://www.3h3.com
  • 环境:Windows7, Windows10, WindowsAll

相关软件

The Ultimate Hands-on Flutter | And Mvvm - Build ...

// repositories/user_repository.dart import '../models/user.dart'; import '../services/api_service.dart'; class UserRepository final ApiService _api = ApiService(); Future<List<User>> getUsers() async final data = await _api.fetchUsers(); return data.map((json) => User.fromJson(json)).toList();

class MyApp extends StatelessWidget @override Widget build(BuildContext context) return ChangeNotifierProvider( create: (ctx) => UserViewModel(), child: MaterialApp(home: UserScreen()), );

// views/user_screen.dart import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; import '../viewmodels/user_viewmodel.dart'; class UserScreen extends StatelessWidget @override Widget build(BuildContext context) final viewModel = Provider.of<UserViewModel>(context); return Scaffold( appBar: AppBar(title: Text("MVVM Users")), body: viewModel.isLoading ? Center(child: CircularProgressIndicator()) : ListView.builder( itemCount: viewModel.users.length, itemBuilder: (ctx, i) => ListTile( title: Text(viewModel.users[i].name), ), ), floatingActionButton: FloatingActionButton( onPressed: () => viewModel.fetchUsers(), child: Icon(Icons.refresh), ), ); The Ultimate Hands-On Flutter and MVVM - Build ...

List<User> get users => _users; bool get isLoading => _isLoading;

Future<List<dynamic>> fetchUsers() async final response = await http.get(Uri.parse("$baseUrl/users")); if (response.statusCode == 200) return json.decode(response.body); else throw Exception("Failed to load users"); // repositories/user_repository

It sounds like you’re referring to a course (likely on Udemy or similar) titled something like:

// services/api_service.dart import 'dart:convert'; import 'package:http/http.dart' as http; class ApiService final String baseUrl = "https://jsonplaceholder.typicode.com"; return data.map((json) =&gt

import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; import 'viewmodels/user_viewmodel.dart'; import 'views/user_screen.dart'; void main() => runApp(MyApp());

// viewmodels/user_viewmodel.dart import 'package:flutter/material.dart'; import '../models/user.dart'; import '../repositories/user_repository.dart'; class UserViewModel extends ChangeNotifier final UserRepository _repository = UserRepository(); List<User> _users = []; bool _isLoading = false;

返回顶部