gpt4 book ai didi

android - setState 不适用于 Flutter 中的 DropDown 按钮

转载 作者:IT王子 更新时间:2023-10-29 06:40:04 24 4
gpt4 key购买 nike

当我从下拉列表中选择数量时,我正在根据数量计算总数,它会发生变化,但总金额 Textformfield 保持不变,当我调试代码时,我会在 setState 中获得更新的金额 方法,但不会反射(reflect)在 UI 上,而且我还在使用该方法中的另一种方法更新总数。

 class _ProductDetailsPageState extends State<ProductDetailsPage> {


List _quantity = ["1", "2", "3", "4", "5"];
List<DropdownMenuItem<String>> _dropDownQuantity;

String _currentQuantity;
String _productprice;
double _taxrateamt;
double _taxper = 0.0;
String _producttotal;
int _productqty;
double _discount = 3.0;
String _productname;

List<DropdownMenuItem<String>> getDropDownQuantity() {
List<DropdownMenuItem<String>> items = new List();
for (String city in _quantity) {
items.add(new DropdownMenuItem(
value: city,
child: new Text(
city,
style:
TextStyle(color: MyColors.colorPrimary, fontFamily: 'semibold'),
)));
}
return items;
}

@override
void initState() {
super.initState();

_dropDownQuantity = getDropDownQuantity();
_currentQuantity = _dropDownQuantity[0].value;
}

Container rateAndTotal( String value) {
return Container(
child: Column(
children: <Widget>[
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: <Widget>[
Expanded(
flex: 1,
child: Container(
child: TextFormField(
style: TextStyle(
fontFamily: 'medium', color: MyColors.colorPrimaryDark),
keyboardType: TextInputType.number,
enabled: false,
textInputAction: TextInputAction.done,
initialValue: '${value}',
decoration: InputDecoration(
border: InputBorder.none, hintText: '$value'),),),),],),],),);}

Container quantity() {
return Container(
child: Column(
children: <Widget>[
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: <Widget>[
Expanded(
flex:1,
child: Container(
child: DropdownButtonHideUnderline(
child: DropdownButton(
value: _currentQuantity,
items: _dropDownQuantity,
onChanged: changedDropDownQuantity,),)),),],),],),);}

@override
Widget build(BuildContext context) {

MediaQueryData queryData;
queryData = MediaQuery.of(context);
double width = queryData.size.width;
double height = queryData.size.height;

return new Container(
height: double.infinity,
decoration: BoxDecoration(color: Colors.grey[200]),
child: SingleChildScrollView(
child: Container(
padding: EdgeInsets.all(height * 0.020),
child: Column(
children: <Widget>[
quantity(),
rateAndTotal( '${_productprice}'),
],
),
),
),
);
}

void changedDropDownQuantity(String selected_quantity) {
setState(() {
_currentQuantity = selected_quantity;
// _producttotal=getProductTotal(_productprice,_currentQuantity);
});

setState(() {
_producttotal=getProductTotal(_productprice,_currentQuantity);
});

}

String getProductTotal(String productprice, String _currentQuantity) {
try {

double sprice = 0.0;
double total = double.parse(productprice);
double taxrate = _taxrateamt;
double qty = double.parse(_currentQuantity);

return _producttotal =
(((total + taxrate + sprice) - _discount) * qty).toString();
} catch (e) {
debugPrint('PRODUCT TOTAl EXC.:--${e}');

return _producttotal = productprice;
}
}
}

enter image description here

最佳答案

要解决此问题,请替换您的 TextFormField 中的以下行:

initialValue: '$value',

与:

controller: TextEditingController(text: value),

或者更好:

// Define a controller in the State
class _ProductDetailsPageState extends State<ProductDetailsPage> {
TextEditingController _controller = TextEditingController(text: value);

...
// Then bind that controller to your TextFormField, replacing initialValue
child: TextFormField(
controller: _controller,

...

// Then change the .text property of that controller when you want it to update
setState(() => _controller.text = value);

initialValue 仅用于设置当 State 首次初始化时 TextFormField 的第一个值,并且 State 通过重建得以保留,因此覆盖它永远不会导致文本更改。

每次完全覆盖 TextEditingController 或定义一个 TextEditingController 并更改 .text 属性将正确地将更改传递给 字段状态并更新您的值。

关于android - setState 不适用于 Flutter 中的 DropDown 按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54903447/

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