flutter - 以编程方式更改 DropdownButtonFormField 值

标签 flutter

我正在尝试使用 setState 更改事件(例如按下按钮)的 DropdownButtonFormField 值。但它不起作用。

注意:如果我使用 DropdownButton,它可以工作,但使用 DropdownButtonFormField 它没有响应。

这是一个简单的代码,显示了我正在尝试实现的内容。

import 'package:flutter/material.dart';

void main() {
runApp(MyApp());
}

class MyApp extends StatelessWidget {
 @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: Testing(),
    );
  }
}

class Testing extends StatefulWidget {
  @override
  _TestingState createState() => _TestingState();
}

class _TestingState extends State<Testing> {
  String selectedValue;
  @override
  Widget build(BuildContext context) {
    return Material(
      child: Column(
        children: <Widget>[
          DropdownButtonFormField(
            value: selectedValue,
            items: ['one', 'two'].map((value) {
              return DropdownMenuItem<String>(
                value: value,
                child: Text(value),
              );
            }).toList(),
            onChanged: (value) {
              setState(() {
                selectedValue = value;
              }); 
            },
          ),
          RaisedButton(
            child: Text('test'),
            onPressed: (){
              setState(() {
                selectedValue = 'two';
              });
            },
          ),
        ],
      ),
    );
  }
}

最佳答案

从 Global Key 定义实例变量并将其传递给 DropdownButtonFormField

final dropdownState = GlobalKey<FormFieldState>();

你可以通过调用这个方法来改变dropDownFieldItem的值

dropdownState.currentState.didChange('two');

最终代码:

import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: Testing(),
    );
  }
}

class Testing extends StatefulWidget {
  @override
  _TestingState createState() => _TestingState();
}

class _TestingState extends State<Testing> {
  String selectedValue;
  final dropdownState = GlobalKey<FormFieldState>();

  @override
  Widget build(BuildContext context) {
    return Material(
      child: Column(
        children: <Widget>[
          DropdownButtonFormField(
            key: dropdownState,
            value: selectedValue,
            items: ['one', 'two'].map((value) {
              return DropdownMenuItem<String>(
                value: value,
                child: Text(value),
              );
            }).toList(),
            onChanged: (value) {
              setState(() {
                selectedValue = value;
              });
            },
          ),
          RaisedButton(
            child: Text('test'),
            onPressed: () {
              dropdownState.currentState.didChange('one');
            },
          ),
        ],
      ),
    );
  }
}

关于flutter - 以编程方式更改 DropdownButtonFormField 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61600934/

相关文章:

flutter - 如何修复列中的 ListView 并将 RefreshIndicator 添加到 ListView

firebase - 如果不存在,则在 firestore 中创建集合( flutter )

flutter - 类型 'Future<dynamic>' 不是类型转换中类型 'List<dynamic>' 的子类型

firebase - 如何等待文件上传到 Flutter 中的 Firebase 存储?

flutter - FirebaseDynamicLinks getInitialLink() 多次触发

flutter - 按字母顺序排序列表

flutter - 如何忽略小部件的鼠标悬停事件?

firebase - 如何将 Flutter TextField 与 Firestore 字段同步?

dart - 如何在 flutter 中设置日期选择器的默认日期?

flutter - 没有为该类定义方法 pickImage