如何解决如何在statelessWidget类中使用setState函数
我无法在setState
中使用dialogContent
函数,但出现此错误:
The method 'setState' isn't defined for the class 'CustomDialog'
在这里我使用了setState()
Row(
mainAxisAlignment: MainAxisAlignment.center,crossAxisAlignment: CrossAxisAlignment.center,children: status ? <Widget>[
Container(
child: Padding(
padding: EdgeInsets.only(right: 5,top: 0),child: Image.asset(
'assets/images/profile.png',width: 60.0,height: 60.0,),Padding(
padding: const EdgeInsets.only(top: 0.0),child: Container(
width: 200.0,decoration: Boxdecoration(
color: Colors.white,borderRadius: BorderRadius.only(
topLeft: const Radius.circular(50.0),topRight: const Radius.circular(50.0),bottomLeft: const Radius.circular(50.0),bottomright: const Radius.circular(50.0),child: Padding(
padding: const EdgeInsets.all(20.0),child: Center(
child: Text(
'test',style: TextStyle(
color: Colors.black,fontWeight: FontWeight.bold,fontSize: 25.0
),)
),Padding(
padding: const EdgeInsets.only(left: 5.0),child: CustomSwitch(
activeColor: Colors.green,value: status,onChanged: (value) {
print("VALUE : $value");
setState(() {
status = value;
});
},] :
[
Expanded(
child: Padding(
padding: const EdgeInsets.only(left :25.0),child: Center(
child: Text(
'test',style: TextStyle(
color: Colors.red,fontSize: 15.0,Padding(
padding: const EdgeInsets.only(left: 0.0),]
),
解决方法
确保您不能在StatelessWidget中使用setState(),这就是此小部件的想法。 StatelessWidget应该仅用于不包含任何状态的“哑”视图。 如果您应该为窗口小部件设置任何状态,请考虑使用StatefulWidget。
看看正式的flutter文档: https://api.flutter.dev/flutter/widgets/StatelessWidget-class.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。