質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
86.12%
Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

解決済

作成したリストをスワイプで削除したい

zisinnasi
zisinnasi

総合スコア3

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

1回答

0リアクション

0クリップ

269閲覧

投稿2022/08/31 02:42

前提

flutterで入力内容を登録するとリストを作成し、
そのリストをスワイプで削除するようなプログラムを勉強しています

実現したいこと

作成したリストをスワイプで消したい

発生している問題・エラーメッセージ

リストをスワイプで削除したいができない

該当のソースコード

dart

import 'package:flutter/material.dart'; import 'package:shared_preferences/shared_preferences.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); Widget build(BuildContext context) { return MaterialApp( title: 'Flutter Demo', theme: ThemeData( primarySwatch: Colors.blue, ), home: const MyHomePage(), ); } } class MyHomePage extends StatefulWidget { const MyHomePage({Key? key}) : super(key: key); State<MyHomePage> createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { List<String> todolist=[]; late String? tmp; late TextEditingController _todoInputController; void initState() { // TODO: implement initState super.initState(); _todoInputController = TextEditingController(); } void dispose() { // TODO: implement dispose super.dispose(); _todoInputController.dispose(); } Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text('ToDo'), ), body: Column( children: [ Padding( padding: EdgeInsets.all(20), child: TextField( controller: _todoInputController, decoration: InputDecoration(hintText: '入力してください'), ), ), Padding( padding: EdgeInsets.all(20), child: RaisedButton( onPressed: ()async{ var prefs = await SharedPreferences.getInstance(); await prefs.setString('code', _todoInputController.text); tmp = await prefs.getString('code'); setState(() { print(tmp); if(tmp!.length>0){ todolist.add(tmp!); _todoInputController.clear(); }; }); }, ), ), Expanded( child:ListView.builder( itemCount: todolist.length, itemBuilder: (BuildContext context,int index){ return Container( child: ListTile( leading: Icon(Icons.circle), title: Text( ("$index : ${todolist[index]}") ), trailing: Dismissible( onDismissed: (direction){ setState((){todolist.removeAt(index);}); }, key: UniqueKey(), child: ListTile( title: Text(todolist[index]), ), ), ), ); }, ), ), ], ), ); } }

試したこと

RowでDismissibleを追加したが、RenderBox was not laid out:でできない

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
86.12%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。