← Каталог
Flutter — готовые виджеты — Список задач
Фрагмент из «Flutter — готовые виджеты»: Список задач.
import 'package:flutter/material.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(home: const TodoScreen());
}
}
class TodoScreen extends StatefulWidget {
const TodoScreen({super.key});
@override
State<TodoScreen> createState() => _TodoScreenState();
}
class _TodoScreenState extends State<TodoScreen> {
final _controller = TextEditingController();
final List<String> _items = [];
@override
void dispose() {
_controller.dispose();
super.dispose();
}
void _addItem() {
final text = _controller.text.trim();
if (text.isEmpty) return;
setState(() {
_items.add(text);
_controller.clear();
});
}
void _removeAt(int index) {
setState(() => _items.removeAt(index));
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Список задач')),
body: Column(
children: [
Padding(
padding: const EdgeInsets.all(8),
child: Row(
children: [
Expanded(
child: TextField(
controller: _controller,
decoration: const InputDecoration(
hintText: 'Новая задача',
border: OutlineInputBorder
isDense: true,
),
onSubmitted: (_) => _addItem
),
),
IconButton(
onPressed: _addItem,
icon: const Icon(Icons.add_circle),
tooltip: 'Добавить',
),
],
),
),
Expanded(
child: _items.isEmpty
? const Center(child: Text('Список пуст — добавьте задачу'))
: ListView.builder(
itemCount: _items.length,
itemBuilder: (context, index) {
return ListTile(
leading: CircleAvatar(child: Text('${index + 1}')),
title: Text(_items[index]),
trailing: IconButton(
icon: const Icon(Icons.delete_outline),
onPressed: () => _removeAt(index),
),
);
},
),
),
],
),
);
}
} import 'package:flutter/material.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(home: const TodoScreen());
}
}
class TodoScreen extends StatefulWidget {
const TodoScreen({super.key});
@override
State<TodoScreen> createState() => _TodoScreenState();
}
class _TodoScreenState extends State<TodoScreen> {
final _controller = TextEditingController();
final List<String> _items = [];
@override
void dispose() {
_controller.dispose();
super.dispose();
}
void _addItem() {
final text = _controller.text.trim();
if (text.isEmpty) return;
setState(() {
_items.add(text);
_controller.clear();
});
}
void _removeAt(int index) {
setState(() => _items.removeAt(index));
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Список задач')),
body: Column(
children: [
Padding(
padding: const EdgeInsets.all(8),
child: Row(
children: [
Expanded(
child: TextField(
controller: _controller,
decoration: const InputDecoration(
hintText: 'Новая задача',
border: OutlineInputBorder
isDense: true,
),
onSubmitted: (_) => _addItem
),
),
IconButton(
onPressed: _addItem,
icon: const Icon(Icons.add_circle),
tooltip: 'Добавить',
),
],
),
),
Expanded(
child: _items.isEmpty
? const Center(child: Text('Список пуст — добавьте задачу'))
: ListView.builder(
itemCount: _items.length,
itemBuilder: (context, index) {
return ListTile(
leading: CircleAvatar(child: Text('${index + 1}')),
title: Text(_items[index]),
trailing: IconButton(
icon: const Icon(Icons.delete_outline),
onPressed: () => _removeAt(index),
),
);
},
),
),
],
),
);
}
}