BottomNavigationBar 保存偏移位置并导航到细节颤动
BottomNavigationBar saving offset position and navigating to details flutter
我是 flutter 的新手。我在项目中使用范围模型(和自动身份验证),我在 MaterialApp class
上使用路由
@override
void initState() {
_model.autoAuthenticate();
_model.userSubject.listen((bool isAuthenticated){
setState(() {
_isAuthenticated = isAuthenticated;
});
});
print('is auth $_isAuthenticated');
super.initState();
}
@override
Widget build(BuildContext context) {
return ScopedModel<MainModel>(
model: _model,
child: MaterialApp(
debugShowCheckedModeBanner: false,
theme: getAdaptiveThemeData(context),
routes: {
'/': (BuildContext context) => !_isAuthenticated ? WelcomePage() : MainPage(_model),
'/info': (BuildContext context) => InfoPage(),
// another code
在我的“/”路线中,我将 MainPage() 与 4 个 bottomNavigationBarItems 和 4 个不同的页面一起使用代码:
int _currentTab = 0;
final List<Widget> _children = [
ScopedModelDescendant<MainModel>(
builder: (BuildContext context, Widget child, MainModel model){
return ProfilePage(model);
},
),
OnStockPage(),
SendPage(),
PppPage()
];
并在构建小部件中:
@override
Widget build(BuildContext context) {
if(widget.model.isUserChanged){
widget.model.getUserProfile().then((model){
}).catchError((error){
print('error is $error');
});
}
print('build first');
return StreamBuilder<UserModel>(
stream: _bloc.user,
builder: (BuildContext context, AsyncSnapshot<UserModel> snapshot){
return Scaffold(
appBar: AppBar(
title: ScopedModelDescendant<MainModel>(
builder: (BuildContext context, Widget child, MainModel model){
return ListTile(
title: model.isLoading ? Text('name surname', style: TextStyle(color: Colors.white, fontWeight: FontWeight.bold)) : Text('${model.profile.firstName} ${model.profile.lastName}', style: TextStyle(color: Colors.white, fontWeight: FontWeight.bold),),
subtitle: Text('Баланс $0', style: TextStyle(color: Colors.white),),
);
},
),
elevation: 0,
),
drawer: DrawerSettings(),
body:_children[_currentTab],
bottomNavigationBar: BottomNavigationBar(
currentIndex: _currentTab,
items: [
BottomNavigationBarItem(
icon: Icon(Icons.person, color: Colors.black,),
title: Text('Профиль', style: TextStyle(color: Colors.black),)
),
BottomNavigationBarItem(
icon: Icon(Icons.check_box_outline_blank, color: Colors.black),
title: Text('На складе', style: TextStyle(color: Colors.black),)
),
BottomNavigationBarItem(
icon: Icon(Icons.drive_eta, color: Colors.black),
title: Text('Отправленные', style: TextStyle(color: Colors.black),)
),
BottomNavigationBarItem(
icon: Icon(Icons.shopping_cart, color: Colors.black),
title: Text('ПпП', style: TextStyle(color: Colors.black))
),
],
onTap: _onTabTapped,
),
);
},
);
}
但是当我在第一个底部项目时,我加载了所有数据,一切都很好,但是当我转到第二个底部项目并返回时,所有数据都再次加载,没有保存,等等。我发现了一些使用 Navigator class 和 Offstage class 使用 bottomNavigationBar 的代码,但他们没有使用 MaterialApp -> 路由,但我使用了,因此存在冲突.. 这里是 link:https://medium.com/coding-with-flutter/flutter-case-study-multiple-navigators-with-bottomnavigationbar-90eb6caa6dbf
我希望应用程序已经知道这些页面,而不是不断调用它。请帮助我
我在 Scaffold class ->
的正文中找到了我的问题的解决方案。
body:_body(),
和
Widget _body(){
return Stack(
children: List<Widget>.generate(_pageCount, (int index){
return IgnorePointer(
ignoring: index != _currentTab,
child: Opacity(
opacity: _currentTab == index ? 1 : 0,
child: Navigator(
onGenerateRoute: (RouteSettings settings){
print('settings ${settings.name}');
if(settings.name == '/'){
return MaterialPageRoute(
builder: (_) => _page(index),
settings: settings
);
}
},
),
),
);
})
);
}
Widget _page(int index){
switch (index){
case 0:
return ScopedModelDescendant<MainModel>(
builder: (BuildContext context, Widget child, MainModel model){
return /*(model.isLoading) ? Center(
child: CircularProgressIndicator(),
) : */ProfilePage(model);
},
);
case 1:
return OnStockPage();
case 2:
return SendPage();
case 3:
return PppPage();
}
throw "Invalid index $index";
}
我是 flutter 的新手。我在项目中使用范围模型(和自动身份验证),我在 MaterialApp class
上使用路由@override
void initState() {
_model.autoAuthenticate();
_model.userSubject.listen((bool isAuthenticated){
setState(() {
_isAuthenticated = isAuthenticated;
});
});
print('is auth $_isAuthenticated');
super.initState();
}
@override
Widget build(BuildContext context) {
return ScopedModel<MainModel>(
model: _model,
child: MaterialApp(
debugShowCheckedModeBanner: false,
theme: getAdaptiveThemeData(context),
routes: {
'/': (BuildContext context) => !_isAuthenticated ? WelcomePage() : MainPage(_model),
'/info': (BuildContext context) => InfoPage(),
// another code
在我的“/”路线中,我将 MainPage() 与 4 个 bottomNavigationBarItems 和 4 个不同的页面一起使用代码:
int _currentTab = 0;
final List<Widget> _children = [
ScopedModelDescendant<MainModel>(
builder: (BuildContext context, Widget child, MainModel model){
return ProfilePage(model);
},
),
OnStockPage(),
SendPage(),
PppPage()
];
并在构建小部件中:
@override
Widget build(BuildContext context) {
if(widget.model.isUserChanged){
widget.model.getUserProfile().then((model){
}).catchError((error){
print('error is $error');
});
}
print('build first');
return StreamBuilder<UserModel>(
stream: _bloc.user,
builder: (BuildContext context, AsyncSnapshot<UserModel> snapshot){
return Scaffold(
appBar: AppBar(
title: ScopedModelDescendant<MainModel>(
builder: (BuildContext context, Widget child, MainModel model){
return ListTile(
title: model.isLoading ? Text('name surname', style: TextStyle(color: Colors.white, fontWeight: FontWeight.bold)) : Text('${model.profile.firstName} ${model.profile.lastName}', style: TextStyle(color: Colors.white, fontWeight: FontWeight.bold),),
subtitle: Text('Баланс $0', style: TextStyle(color: Colors.white),),
);
},
),
elevation: 0,
),
drawer: DrawerSettings(),
body:_children[_currentTab],
bottomNavigationBar: BottomNavigationBar(
currentIndex: _currentTab,
items: [
BottomNavigationBarItem(
icon: Icon(Icons.person, color: Colors.black,),
title: Text('Профиль', style: TextStyle(color: Colors.black),)
),
BottomNavigationBarItem(
icon: Icon(Icons.check_box_outline_blank, color: Colors.black),
title: Text('На складе', style: TextStyle(color: Colors.black),)
),
BottomNavigationBarItem(
icon: Icon(Icons.drive_eta, color: Colors.black),
title: Text('Отправленные', style: TextStyle(color: Colors.black),)
),
BottomNavigationBarItem(
icon: Icon(Icons.shopping_cart, color: Colors.black),
title: Text('ПпП', style: TextStyle(color: Colors.black))
),
],
onTap: _onTabTapped,
),
);
},
);
}
但是当我在第一个底部项目时,我加载了所有数据,一切都很好,但是当我转到第二个底部项目并返回时,所有数据都再次加载,没有保存,等等。我发现了一些使用 Navigator class 和 Offstage class 使用 bottomNavigationBar 的代码,但他们没有使用 MaterialApp -> 路由,但我使用了,因此存在冲突.. 这里是 link:https://medium.com/coding-with-flutter/flutter-case-study-multiple-navigators-with-bottomnavigationbar-90eb6caa6dbf 我希望应用程序已经知道这些页面,而不是不断调用它。请帮助我
我在 Scaffold class ->
的正文中找到了我的问题的解决方案。body:_body(),
和
Widget _body(){
return Stack(
children: List<Widget>.generate(_pageCount, (int index){
return IgnorePointer(
ignoring: index != _currentTab,
child: Opacity(
opacity: _currentTab == index ? 1 : 0,
child: Navigator(
onGenerateRoute: (RouteSettings settings){
print('settings ${settings.name}');
if(settings.name == '/'){
return MaterialPageRoute(
builder: (_) => _page(index),
settings: settings
);
}
},
),
),
);
})
);
}
Widget _page(int index){
switch (index){
case 0:
return ScopedModelDescendant<MainModel>(
builder: (BuildContext context, Widget child, MainModel model){
return /*(model.isLoading) ? Center(
child: CircularProgressIndicator(),
) : */ProfilePage(model);
},
);
case 1:
return OnStockPage();
case 2:
return SendPage();
case 3:
return PppPage();
}
throw "Invalid index $index";
}