Eri*_*yes 3 counter product flutter
我在flutter中做一个包含产品的应用,我需要做的是能够增加并获取要存储的增加产品的密钥,目前它们都在增加。
我留下了图片和我的代码,感谢您的帮助
Widget _buildSearchResults() {
return new ListView.builder(
itemCount: _productSearchResult.length,
itemBuilder: (context, i) {
return new Card(
child: Column(
children: <Widget>[
ExpansionTile(
leading: new CircleAvatar(
backgroundImage: new NetworkImage(_productSearchResult[i].image_url),
),
title: new Text(
'${_productSearchResult[i].name} \nPrecio: Q${_productSearchResult[i].price} / Medida: ${_productSearchResult[i].unit } ',
),
children: <Widget>[
Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
new Container(
child: new IconButton(
icon: new Icon(Icons.remove),
highlightColor: Colors.green,
onPressed: (){
_removeProduct();
},
),
),
new Container(
child: new Text('$_counter',
style: Theme.of(context).textTheme.display1,),
),
new Container(
child: new IconButton(
icon: new Icon(Icons.add),
highlightColor: Colors.green,
onPressed: (){
_addProduct();
},
),
),
new Container(
padding: new EdgeInsets.all(10.0),
width: 100.0,
child: new RaisedButton(
padding: const EdgeInsets.all(8.0),
textColor: Colors.white,
color: Colors.green,
onPressed: _addNumbers,
child: new Text("Agregar"),
),
),
]
),
]
),
],
)
);
},
);
Run Code Online (Sandbox Code Playgroud)
}
_removeProduct() {
setState(() {
if (_counter > 0) {
_counter--;
}
});
Run Code Online (Sandbox Code Playgroud)
}
_addProduct() {
setState(() {
_counter++;
});
Run Code Online (Sandbox Code Playgroud)
}
您的所有产品都有一个计数器,这就是为什么它为所有产品显示相同的价值。您需要在您的 _productSearchResult 模型中添加您的计数器并在那里增加它。而不是显示
Text('$_counter',
Run Code Online (Sandbox Code Playgroud)
你会显示
Text('${_productSearchResult[i].counter}',
Run Code Online (Sandbox Code Playgroud)
并且您将更改 addProduct 方法以接收索引,以便您可以增加每个产品的计数器。
_addProduct(int index) {
setState(() {
_productSearchResult[index].counter++;
});
Run Code Online (Sandbox Code Playgroud)
和删除产品相同。
| 归档时间: |
|
| 查看次数: |
4137 次 |
| 最近记录: |