gpt4 book ai didi

select - flutter 中是否有与 HTML 中的 "select multiple"元素等效的小部件

转载 作者:IT王子 更新时间:2023-10-29 07:07:43 25 4
gpt4 key购买 nike

我在 flutter 中搜索一个等于

<select multiple=""></select>

在 flutter 中。

一个示例实现(用于网络)是 MaterializeCSS Select Multiple

如上所示,我应该能够提供项目列表(其中一些是预选的)并在最后检索所选项目的列表或 map 或其他内容。

非常感谢示例实现或文档链接。

最佳答案

我认为 Flutter 中目前不存在这样的小部件,但您可以自己构建一个。

在屏幕空间有限的手机上,显示带有提交按钮的对话框可能是有意义的,例如 this native Android dialog .

下面是如何用不到 100 行代码实现这样一个对话框的粗略草图:

class MultiSelectDialogItem<V> {
const MultiSelectDialogItem(this.value, this.label);

final V value;
final String label;
}

class MultiSelectDialog<V> extends StatefulWidget {
MultiSelectDialog({Key key, this.items, this.initialSelectedValues}) : super(key: key);

final List<MultiSelectDialogItem<V>> items;
final Set<V> initialSelectedValues;

@override
State<StatefulWidget> createState() => _MultiSelectDialogState<V>();
}

class _MultiSelectDialogState<V> extends State<MultiSelectDialog<V>> {
final _selectedValues = Set<V>();

void initState() {
super.initState();
if (widget.initialSelectedValues != null) {
_selectedValues.addAll(widget.initialSelectedValues);
}
}

void _onItemCheckedChange(V itemValue, bool checked) {
setState(() {
if (checked) {
_selectedValues.add(itemValue);
} else {
_selectedValues.remove(itemValue);
}
});
}

void _onCancelTap() {
Navigator.pop(context);
}

void _onSubmitTap() {
Navigator.pop(context, _selectedValues);
}

@override
Widget build(BuildContext context) {
return AlertDialog(
title: Text('Select animals'),
contentPadding: EdgeInsets.only(top: 12.0),
content: SingleChildScrollView(
child: ListTileTheme(
contentPadding: EdgeInsets.fromLTRB(14.0, 0.0, 24.0, 0.0),
child: ListBody(
children: widget.items.map(_buildItem).toList(),
),
),
),
actions: <Widget>[
FlatButton(
child: Text('CANCEL'),
onPressed: _onCancelTap,
),
FlatButton(
child: Text('OK'),
onPressed: _onSubmitTap,
)
],
);
}

Widget _buildItem(MultiSelectDialogItem<V> item) {
final checked = _selectedValues.contains(item.value);
return CheckboxListTile(
value: checked,
title: Text(item.label),
controlAffinity: ListTileControlAffinity.leading,
onChanged: (checked) => _onItemCheckedChange(item.value, checked),
);
}
}

你可以这样使用它:

void _showMultiSelect(BuildContext context) async {
final items = <MultiSelectDialogItem<int>>[
MultiSelectDialogItem(1, 'Dog'),
MultiSelectDialogItem(2, 'Cat'),
MultiSelectDialogItem(3, 'Mouse'),
];

final selectedValues = await showDialog<Set<int>>(
context: context,
builder: (BuildContext context) {
return MultiSelectDialog(
items: items,
initialSelectedValues: [1, 3].toSet(),
);
},
);

print(selectedValues);
}

关于select - flutter 中是否有与 HTML 中的 "select multiple"元素等效的小部件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51975690/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com