여기서 할 수있는 일이 몇 가지 있습니다. @Mahi의 대답은 정확하지만 조금 더 간결 할 수 있으며 실제로 OP가 묻는 것처럼 showDialog보다 푸시를 사용합니다. 다음을 사용하는 예입니다 Navigator.push
.
import 'package:flutter/material.dart';
class SecondPage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new Container(
color: Colors.green,
child: new Column(
children: <Widget>[
new RaisedButton(
onPressed: () => Navigator.pop(context),
child: new Text("back"),
),
],
),
);
}
}
class FirstPage extends StatefulWidget {
@override
State<StatefulWidget> createState() => new FirstPageState();
}
class FirstPageState extends State<FirstPage> {
Color color = Colors.white;
@override
Widget build(BuildContext context) {
return new Container(
color: color,
child: new Column(
children: <Widget>[
new RaisedButton(
child: new Text("next"),
onPressed: () {
Navigator
.push(
context,
new MaterialPageRoute(builder: (context) => new SecondPage()),
)
.then((value) {
setState(() {
color = color == Colors.white ? Colors.grey : Colors.white;
});
});
}),
],
),
);
}
}
void main() => runApp(
new MaterialApp(
builder: (context, child) => new SafeArea(child: child),
home: new FirstPage(),
),
);
그러나 사용 사례에 잘 맞는 다른 방법이 있습니다. 을 global
첫 페이지의 빌드에 영향을주는 것으로 사용하는 경우 InheritedWidget 을 사용하여 전역 사용자 환경 설정을 정의 할 수 있으며 변경 될 때마다 FirstPage가 다시 빌드됩니다. 이는 아래에 표시된 것처럼 상태 비 저장 위젯에서도 작동합니다 (그러나 상태 저장 위젯에서도 작동해야 함).
flutter에서 inheritedWidget의 예는 앱의 테마입니다.하지만 여기 에서처럼 직접 빌드하는 대신 위젯 내에서 정의합니다.
import 'package:flutter/material.dart';
import 'package:meta/meta.dart';
class SecondPage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new Container(
color: Colors.green,
child: new Column(
children: <Widget>[
new RaisedButton(
onPressed: () {
ColorDefinition.of(context).toggleColor();
Navigator.pop(context);
},
child: new Text("back"),
),
],
),
);
}
}
class ColorDefinition extends InheritedWidget {
ColorDefinition({
Key key,
@required Widget child,
}): super(key: key, child: child);
Color color = Colors.white;
static ColorDefinition of(BuildContext context) {
return context.inheritFromWidgetOfExactType(ColorDefinition);
}
void toggleColor() {
color = color == Colors.white ? Colors.grey : Colors.white;
print("color set to $color");
}
@override
bool updateShouldNotify(ColorDefinition oldWidget) =>
color != oldWidget.color;
}
class FirstPage extends StatelessWidget {
@override
Widget build(BuildContext context) {
var color = ColorDefinition.of(context).color;
return new Container(
color: color,
child: new Column(
children: <Widget>[
new RaisedButton(
child: new Text("next"),
onPressed: () {
Navigator.push(
context,
new MaterialPageRoute(builder: (context) => new SecondPage()),
);
}),
],
),
);
}
}
void main() => runApp(
new MaterialApp(
builder: (context, child) => new SafeArea(
child: new ColorDefinition(child: child),
),
home: new FirstPage(),
),
);
상속 된 위젯을 사용하는 경우 푸시 한 페이지의 팝업을 지켜 보는 것에 대해 걱정할 필요가 없습니다. 기본 사용 사례에서는 작동하지만 더 복잡한 시나리오에서는 문제가 발생할 수 있습니다.