- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不明白为什么在这里不接受提供者。
我的main.dart看起来像这样。
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
debugShowCheckedModeBanner: false,
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: ChangeNotifierProvider<ContentDS>(
builder: (_) => ContentDS(),
child: Content(),
)
);
}
}
Navigator.of(ctx).push(MaterialPageRoute(
builder: (context) =>
ContentDetails(viewedList: listElement),
))
final ds = Provider.of<ContentDS>(context);
To fix, please:
- Ensure the Provider is an ancestor to this ContentDetails Widget * Provide types to Provider * Provide types to Consumer * Provide types to Provider.of() * Always use package imports. Ex:
import
context` is being used.
'package:my_app/my_code.dart'; * Ensure the correct
class ContentDetails extends StatefulWidget {
ToDoList viewedList;
ContentDetails({this.viewedList});
@override
_ContentDetailsState createState() => _ContentDetailsState();
}
class _ContentDetailsState extends State<ContentDetails> with SingleTickerProviderStateMixin{
bool isOpened = false;
AnimationController _animationController;
Animation<Color> _buttonColor;
Animation<double> _animateIcon;
Animation<double> _translateButton;
Curve _curve = Curves.easeOut;
double _fabHeight = 56.0;
initState() {
_animationController =
AnimationController(vsync: this, duration: Duration(milliseconds: 500))
..addListener(() {
setState(() {});
});
_animateIcon =
Tween<double>(begin: 0.0, end: 1.0).animate(_animationController);
_buttonColor = ColorTween(
begin: Colors.blue,
end: Colors.red,
).animate(CurvedAnimation(
parent: _animationController,
curve: Interval(
0.00,
1.00,
curve: Curves.linear,
),
));
_translateButton = Tween<double>(
begin: _fabHeight,
end: -14.0,
).animate(CurvedAnimation(
parent: _animationController,
curve: Interval(
0.0,
0.75,
curve: _curve,
),
));
super.initState();
}
@override
dispose() {
_animationController.dispose();
super.dispose();
}
animate() {
if (!isOpened) {
_animationController.forward();
} else {
_animationController.reverse();
}
isOpened = !isOpened;
}
@override
Widget build(BuildContext context) {
final ds = Provider.of<ContentDS>(context);
print(" ds.count ---> " + ds.count.toString());
if (widget.viewedList != null){
debugPrint(" widget.viewedList.primaryID ---> " + widget.viewedList.primaryID);
}else{
debugPrint(" It is null");
}
return
Hero(
tag: (widget.viewedList != null) ? widget.viewedList.primaryID : 'Hero',
child: Scaffold(
appBar: new AppBar(
backgroundColor: ListStatusHelper.getBgGenericColor(widget.viewedList?.status ?? ListStatus.NONE),
title: Text('${getListTitle()}'),
elevation: 0.0,
),
floatingActionButton: Wrap(
direction: Axis.vertical,
children: <Widget>[
transformWorks(edit(), 3),
transformWorks(save(), 2),
transformWorks(inbox(),1),
toggleButton()
],
),
body: Container(
color: ListStatusHelper.getBgGenericColor(widget.viewedList?.status ?? ListStatus.NONE),
child: const Text("Once Provider is available, need to work on this section");
),
),
);
}
Widget transformWorks(Widget btn, int pos){
return Transform(
transform: Matrix4.translationValues(
0.0,
_translateButton.value * pos,
0.0,
),
child: btn,
);
}
Widget inbox() {
return Container(
child: FloatingActionButton(
heroTag: null,
onPressed: null,
tooltip: 'Inbox',
elevation: 0.0,
child: Icon(Icons.inbox),
),
);
}
Widget edit() {
return Container(
child: FloatingActionButton(
heroTag: null,
onPressed: null,
tooltip: 'Edit',
elevation: 0.0,
child: Icon(Icons.edit),
),
);
}
Widget save() {
return Container(
child: FloatingActionButton(
heroTag: null,
onPressed: null,
tooltip: 'Save',
elevation: 0.0,
child: Icon(Icons.save),
),
);
}
Widget toggleButton(){
return FloatingActionButton(
heroTag: null,
backgroundColor: _buttonColor.value,
onPressed: animate,
tooltip: 'Toggle',
child: AnimatedIcon(
icon: AnimatedIcons.menu_close,
progress: _animateIcon,
),
);
}
String getListTitle() {
if (widget.viewedList != null) {
return widget.viewedList.listTitle;
} else {
return 'New List';
}
}
}
最佳答案
将ChangeNotifier
移到MyApp
之上:
void main() {
runApp(ChangeNotifierProvider(
builder: (context) => ContentDS(),
child: MyApp()));
}
关于flutter - 在包含导航流的Flutter中,此Y小部件上方找不到正确的Provider <X>,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58499354/
假设有一个具有非常简单的 UI 层次结构的窗口,它只有两个同级: NSTextView 和 NSButton,并且它们确实重叠。 我的问题是,为什么光标悬停在按钮上时会有所不同,具体取决于其下方是否有
例如,当我将 TPanel 添加到表单并使用 alTop 对齐它,然后将 TMainMenu 添加到同一表单时,主菜单位置会覆盖面板位置,以便主菜单保持在窗体的最顶层,面板显示在其下方。 是否可以覆盖
我想构建一个 UI,其中我在屏幕顶部有一些固定的小部件(在所有选项卡上可见),然后在它们下面我想要一个 TabBarView(底部有选项卡栏),这是否可能而不使您的自己的标签小部件还是 TabBarV
我一直在这里关注 Phaser 3 的介绍 http://phaser.io/tutorials/making-your-first-phaser-3-game并发现我的 Angular 色“悬停”在
我在 View 中间有一个 UITextView,在 View 底部有一个 UIToolBar。当我触摸 UITextView 时,我希望在 UIToolBar 上方出现一个可视键盘。我该怎么做? 最
我正在尝试制作井字游戏,我有一个 3 x 3 按钮网格,但我想在按钮上方有一个栏,显示分数和玩家姓名,有人可以帮助我吗?到java,不知道从哪里开始。 import javax.swing.*; im
是否可以指定 noUiSlider 绘制的工具提示的位置?似乎默认情况下它将第一个放在 slider 上,第二个放在下面。我理解这里的可用性目标,但我想把两者都放在上面或下面。 示例(带有上方和下方的
我的应用程序中有主详细布局(参见左图): 我为操作栏设置了导航模式列表(使用它来过滤第二个 fragment 中的 ListView ): final ActionBar actionBar = ge
我是 iOS 编程新手,在使用 XLPagerTabStrip(github.com/xmartlabs/XLPagerTabStrip) 时遇到了困难。我按照它的教程,成功在VC的顶部添加了Page
这个问题适用于任何项目,但在这种情况下,我想将我的图像放置在 map 上方,目前它位于 map 下方。 我是 swift 1.2 的新手,所以我不知道如何组合一个示例,任何帮助将不胜感激。 最佳答案
我如何在 javascript 中确定一个元素是否在视口(viewport)上方(用户已经滚动过它)(不仅仅是它是否可见)? 在这段代码中: 控制台日志(iselement1aboveviewport
我正在尝试将工具栏添加到我的 View Controller 。 我的 View Controller : -(void)loadView { UIWebView *webView = [[U
我知道这是一个一般性问题,但任何方向都会有所帮助。 所以我正在使用这个模块 https://github.com/maxep/MXSegmentedPager尝试重新创建 Twitter 的个人资料页
我需要在保存按钮下放置一个带有 id 的 div。这是 html 代码: save 这是我的 : 通过这种方式,div 隐藏了按钮,我的目的是在 div 上方显示按钮。
我试图将我的整个 refreshControl 放在 tableview 后面。我可以通过这样做来放置实际的微调器: self.tableView.addSubview(refreshContro
这在 Safari 和 Firefox 中都会发生。我的导航栏看起来像这样: Test 相关的 CSS 看起来像: li { float: left } a:hover {
我在 CSS 中的 #footermain div 上有一个框阴影,但我无法让它显示在绿色页脚上方。我什么都试过了,还是想不通。 #footermain { background: #1f6c
我试图将图像部分放置在旋转 slider 上方( slider 上侧的一部分应该被图像覆盖)我试过 image{position:relative; z-index:10; } slider{posi
我认为这是一个简单的问题,但我无法理解它。我在页面顶部有一个固定的 div,当我向下滚动查看内容时,内容(文本)显示在该固定 div 上方 5 像素的边距中。该边距(黑色,请参阅 https://js
我有两个 div,在页脚配置中。目的是在悬停时通过显示隐藏的 div 向上扩展页脚。 #extendedFooter, #test { display: none; } #standardFo
我是一名优秀的程序员,十分优秀!