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

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

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

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

Dart

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

解決済

【Flutter】AutoCompleteで候補を選択or選択せずに入力をして、保存後テキストフィールドに入力された文字を削除したい

ouma
ouma

総合スコア15

Flutter

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

Dart

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

1回答

0リアクション

0クリップ

189閲覧

投稿2022/09/28 10:47

前提

Flutterでテキストフィールドに入力して保存ボタンを押すと
テキストフィールドから文字を消したい

実現したいこと

テキストフィールドに候補文字列を出しつつ、
候補を選択したさい、選択しなかった際の入力のどちらも
保存し、保存したあとテキストフィールドの文字を消したい。

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

候補をAutoCompleteで作成し、
AutoCompleteの中のcontrollerをCodeAssumeのウィジェット外から
消去するために、TextEditingControllerを設定したがうまくいかない。

特になし

該当のソースコード

dart

import 'package:flutter/material.dart'; import 'package:flutter/scheduler.dart'; import 'package:flutter/services.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); // This widget is the root of your application. Widget build(BuildContext context) { return MaterialApp( title: 'Flutter Demo', theme: ThemeData( primarySwatch: Colors.blue, ), home: const MyHomePage(title: 'Flutter Demo Home Page'), ); } } class MyHomePage extends StatefulWidget { const MyHomePage({Key? key, required this.title}) : super(key: key); final String title; State<MyHomePage> createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { String _tmpCode=''; String companyCodeName=''; String nonSelectedcompanyname=''; TextEditingController codecompanyEditingController = TextEditingController(); Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text(widget.title), ), body: Center( child: Column( children: [ CodeAssume(context,codecompanyEditingController), IconButton( onPressed: (){ if(companyCodeName!=''){ _tmpCode=companyCodeName.substring(0,4); }else{ _tmpCode=nonSelectedcompanyname; } companyCodeName=''; codecompanyEditingController.text=''; setState(() {}); }, icon: Icon(Icons.save) ), Text(_tmpCode), Text('codecompanyEditingController.text${codecompanyEditingController.text}') ], ), ), ); } Widget CodeAssume(BuildContext context,codecompanyEditingController) { return Container( width: 80, child: Autocomplete<String>( fieldViewBuilder: ( BuildContext context, codecompanyEditingController, FocusNode focusNode, VoidCallback onFieldSubmitted, ) { return TextField( controller: codecompanyEditingController, focusNode: focusNode, onChanged: (String? value){ nonSelectedcompanyname = value!; }, ); }, optionsBuilder: (TextEditingValue textEditingValue) { if (textEditingValue.text == '') { return const Iterable<String>.empty(); } return _kOption.where((String option) { return option.contains(textEditingValue.text.toLowerCase()); }); }, onSelected: (selection) { companyCodeName = selection; }, ), ); } } List<String> _kOption = <String>[ "aaasdfa", "sasfablo", ];

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

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

Flutter

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

Dart

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