gpt4 book ai didi

android - 使用Flutter Provider软件包时出现问题

转载 作者:行者123 更新时间:2023-12-03 02:52:30 25 4
gpt4 key购买 nike

我正在创建一个非常简单的应用程序来练习Flutter提供程序包。该应用程序具有一个灯泡,单击时应使用提供程序更改其背景和屏幕的背景。但这似乎不起作用。 TBH这很令人困惑

import 'package:flutter/material.dart';
import 'package:provider/provider.dart';

void main() => runApp(MainApp());

class Data extends ChangeNotifier{
bool isOn = false;
void toggle(){
this.isOn = !this.isOn;
notifyListeners();
print("new value is $isOn");
}
}

class MainApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return ChangeNotifierProvider<Data>(
create: (context) => Data(),
child: MaterialApp(
home: Home(),
),
);
}
}

class Home extends StatefulWidget {
@override
_HomeState createState() => _HomeState();
}

class _HomeState extends State<Home> {

@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(),
backgroundColor: Provider.of<Data>(context).isOn ? Colors.yellow[100] : Colors.black,
body: Center(
child: Column(
children: <Widget>[
Stick(),
Bulb(),
],
),
),
);
}
}

class Stick extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Container(
height: 150,
width: 40,
color: Colors.brown,
);
}
}

class Bulb extends StatefulWidget {
@override
_BulbState createState() => _BulbState();
}

class _BulbState extends State<Bulb> {
@override
Widget build(BuildContext context) {
return Container(
height: 200,
width: 250,
decoration: BoxDecoration(
borderRadius: BorderRadius.only(
topLeft: Radius.circular(100),
topRight: Radius.circular(100),
bottomLeft: Radius.circular(30),
bottomRight: Radius.circular(30)),
color: Provider.of<Data>(context).isOn ? Colors.yellow : Colors.white,
),
child: GestureDetector(
onTap: (){
Provider.of<Data>(context).toggle();
setState(() {
});
},
),
);
}
}

树形结构具有一个主应用程序,该主应用程序包含一个Home应用程序,该应用程序还包含两个其他小部件,一个杆和一个位于容器内的灯泡。单击灯泡时,我尝试更新灯泡的背景和“主页”小部件。灯泡有手势检测器
任何提示或帮助表示赞赏

最佳答案

尝试将listen: false添加到提供者调用中:

Provider.of<Data>(context, listen: false).toggle();

关于android - 使用Flutter Provider软件包时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61528820/

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