Flutter 在Flitter中有没有办法在下拉列表中添加更多的项目?
实际上,我想在下拉列表中的一个项目中添加更多的项目,就像Web一样。 请帮帮我,谢谢Flutter 在Flitter中有没有办法在下拉列表中添加更多的项目?,flutter,flutter-layout,dropdown,Flutter,Flutter Layout,Dropdown,实际上,我想在下拉列表中的一个项目中添加更多的项目,就像Web一样。 请帮帮我,谢谢 我创建了自己的小部件,就像这样 import'dart:math'; 进口“包装:颤振/材料.省道”; void main()=>runApp(MyApp()); 类MyApp扩展了无状态小部件{ @凌驾 小部件构建(构建上下文){ 返回材料PP( 标题:“颤振演示”, 主题:主题数据( 主样本:颜色。蓝色, ), 家:脚手架( 正文:安全区( 子:MyHomePage(), ), ), ); } } 类My
我创建了自己的小部件,就像这样
import'dart:math';
进口“包装:颤振/材料.省道”;
void main()=>runApp(MyApp());
类MyApp扩展了无状态小部件{
@凌驾
小部件构建(构建上下文){
返回材料PP(
标题:“颤振演示”,
主题:主题数据(
主样本:颜色。蓝色,
),
家:脚手架(
正文:安全区(
子:MyHomePage(),
),
),
);
}
}
类MyHomePage扩展StatefulWidget{
@凌驾
_MyHomePageState createState()=>\u MyHomePageState();
}
类_MyHomePageState扩展状态{
@凌驾
小部件构建(构建上下文){
返回列表视图(
儿童:[
手风琴(
标题:“1级”,
子:列(
儿童:[
手风琴(
标题:“2级”,
孩子:手风琴(
标题:“三级”,
子:列(
儿童:[
手风琴(
标题:“4级”,
子项:文本(“第4级内容”),
),
],
),
),
),
手风琴(
标题:“2级”,
子项:文本('Level2 content'),
),
],
)),
手风琴(
标题:“1级”,
子项:文本(“级别1内容”),
),
],
);
}
}
类Accordion扩展StatefulWidget{
康斯特手风琴({
关键点,
@需要这个标题,
@需要这个孩子,
}):super(key:key);
最后的字符串标题;
最后一个孩子;
@凌驾
_AccordionState createState()=>\u AccordionState();
}
类_AccordionState扩展状态
使用SingleTickerProviderStateMixin{
动画控制器_控制器;
动画高度因子;
动画;;
bool _isExpanded=false;
@凌驾
无效处置(){
_controller.dispose();
super.dispose();
}
void_handleTap(){
设置状态(){
_isExpanded=!\u isExpanded;
如果(_i扩展){
_controller.forward();
}否则{
_controller.reverse().then((值){
如果(!已安装)返回;
setState((){});
});
}
});
}
@凌驾
void initState(){
_控制器=动画控制器(
持续时间:持续时间(
毫秒:150,
),
vsync:这个,,
);
_高度因子=_controller.drive(曲线之间的曲线(曲线:Curves.easeIn));
_色差=色差(
开始:颜色。灰色,
结束:颜色。黑色87,
).animate(曲线动画(父对象:_控制器,曲线:Curves.easeIn));
super.initState();
}
@凌驾
小部件构建(构建上下文){
返回动画生成器(
动画:_controller.view,
建筑商:(uu,uuu){
返回列(
crossAxisAlignment:crossAxisAlignment.start,
儿童:[
手势检测器(
行为:HitTestBehavior.不透明,
孩子:填充(
填充:从LTRB(10,10,0,10)开始的边缘设置,
孩子:排(
mainAxisAlignment:mainAxisAlignment.spaceBetween,
儿童:[
灵活的(
子:文本(
widget.title,
样式:TextStyle(
fontWeight:fontWeight.bold,
),
),
),
变换。旋转(
角度:pi*_高度因子值*0.5,
子:图标(
Icons.arrow_forward_ios,
颜色:_colorTween.value,
),
)
],
),
),
onTap:_handleTap,
),
克里普雷克特(
子对象:对齐(
对齐:alignment.centerLeft,
高度因子:_heightFactor.value,
孩子:填充(
填充:仅限边缘设置(底部:10,左侧:10),
child:widget.child,
),
),
),
],
);
});
}
}
感谢您的贡献,我们尝试开发您的解决方案,但这无法添加到微调器中
import 'dart:math';
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: Scaffold(
body: SafeArea(
child: MyHomePage(),
),
),
);
}
}
class MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return ListView(
children: [
Accordion(
title: 'Level1',
child: Column(
children: [
Accordion(
title: 'Level2',
child: Accordion(
title: 'Level3',
child: Column(
children: [
Accordion(
title: 'Level4',
child: Text('Level4 content'),
),
],
),
),
),
Accordion(
title: 'Level2',
child: Text('Level2 content'),
),
],
)),
Accordion(
title: 'Level1',
child: Text('Level1 content'),
),
],
);
}
}
class Accordion extends StatefulWidget {
const Accordion({
Key key,
@required this.title,
@required this.child,
}) : super(key: key);
final String title;
final Widget child;
@override
_AccordionState createState() => _AccordionState();
}
class _AccordionState extends State<Accordion>
with SingleTickerProviderStateMixin {
AnimationController _controller;
Animation<double> _heightFactor;
Animation _colorTween;
bool _isExpanded = false;
@override
void dispose() {
_controller.dispose();
super.dispose();
}
void _handleTap() {
setState(() {
_isExpanded = !_isExpanded;
if (_isExpanded) {
_controller.forward();
} else {
_controller.reverse().then<void>((value) {
if (!mounted) return;
setState(() {});
});
}
});
}
@override
void initState() {
_controller = AnimationController(
duration: Duration(
milliseconds: 150,
),
vsync: this,
);
_heightFactor = _controller.drive(CurveTween(curve: Curves.easeIn));
_colorTween = ColorTween(
begin: Colors.grey,
end: Colors.black87,
).animate(CurvedAnimation(parent: _controller, curve: Curves.easeIn));
super.initState();
}
@override
Widget build(BuildContext context) {
return AnimatedBuilder(
animation: _controller.view,
builder: (_, __) {
return Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
GestureDetector(
behavior: HitTestBehavior.opaque,
child: Padding(
padding: EdgeInsets.fromLTRB(10, 10, 0, 10),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: <Widget>[
Flexible(
child: Text(
widget.title,
style: TextStyle(
fontWeight: FontWeight.bold,
),
),
),
Transform.rotate(
angle: pi * _heightFactor.value * 0.5,
child: Icon(
Icons.arrow_forward_ios,
color: _colorTween.value,
),
)
],
),
),
onTap: _handleTap,
),
ClipRect(
child: Align(
alignment: Alignment.centerLeft,
heightFactor: _heightFactor.value,
child: Padding(
padding: EdgeInsets.only(bottom: 10, left: 10),
child: widget.child,
),
),
),
],
);
});
}
}