Flutter 如何在颤振中创建一个可破坏的机载设备(它应该只在第一次安装时可见,而不再可见)?

Flutter 如何在颤振中创建一个可破坏的机载设备(它应该只在第一次安装时可见,而不再可见)?,flutter,dart,Flutter,Dart,您需要使用Navigator.pushReplacement方法,而不是使用Navigator.push方法来移动到下一页 For ex : Navigator.pushReplacement(context, MaterialPageRoute(builder: (context) => NextPage())); 方法将在导航堆栈中添加一个新页面/路由 同时,Navigator.pushReplacement将用flatter中导航堆栈中的下一页/路由替换当前页/路由 用户共享首选

您需要使用Navigator.pushReplacement方法,而不是使用Navigator.push方法来移动到下一页

For ex :

Navigator.pushReplacement(context, MaterialPageRoute(builder: (context) => NextPage()));
方法将在导航堆栈中添加一个新页面/路由

同时,Navigator.pushReplacement将用flatter中导航堆栈中的下一页/路由替换当前页/路由


用户共享首选项,用于存储用户是否在登机屏幕上查看的数据。如果已查看,则不要再次加载此屏幕。并通过替换下面的do代码转到另一个屏幕

bottomSheet: _currentPage == _numPages - 1
      ? Container(
          height: 75.0,
          width: double.infinity,
          color: Colors.white,
          child: GestureDetector(
            onTap: () {
              Navigator.pushReplacementNamed(context, "screen you want to go");
            },
            child: Center(
              child: Padding(
                padding: EdgeInsets.only(bottom: 20.0),
                child: Text(
                  'Get started',
                  textAlign: TextAlign.center,
                  style: TextStyle(
                    color: Color(0xFF5B16D0),
                    fontSize: 18.0,
                    fontWeight: FontWeight.bold,
                  ),
                ),
              ),
            ),
          ),
        )
      : Text(''),

您可以在此emo
initScreen
中,使用
shared\u首选项
来保存显示
车载屏幕
的记录 如果
车载屏幕
以前从未显示过,则显示
车载屏幕
否则移动到另一屏幕

import 'package:flutter/material.dart';
import 'package:shared_preferences/shared_preferences.dart';
import 'package:flutter/services.dart';

int initScreen;

Future<void> main() async {
  WidgetsFlutterBinding.ensureInitialized();

  SharedPreferences prefs = await SharedPreferences.getInstance(); 
  initScreen = await prefs.getInt("initScreen");
  await prefs.setInt("initScreen", 1);
  print('initScreen ${initScreen}');
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      initialRoute: initScreen == 0 || initScreen == null ? "first" : "/",
      routes: {
        '/': (context) => MyHomePage(
              title: "demo",
            ),
        "first": (context) => OnboardingScreen(),
      },
    );
  }
}
导入“包装:颤振/材料.省道”;
导入“package:shared_preferences/shared_preferences.dart”;
导入“包:flifter/services.dart”;
int初始化屏幕;
Future main()异步{
WidgetsFlutterBinding.ensureInitialized();
SharedReferences prefs=等待SharedReferences.getInstance();
initScreen=await prefs.getInt(“initScreen”);
等待prefs.setInt(“初始化屏幕”,1);
打印('initScreen${initScreen}');
runApp(MyApp());
}
类MyApp扩展了无状态小部件{
//此小部件是应用程序的根。
@凌驾
小部件构建(构建上下文){
返回材料PP(
标题:“颤振演示”,
主题:主题数据(
主样本:颜色。蓝色,
),
initialRoute:initScreen==0 | | initScreen==null?“第一个”:“/”,
路线:{
“/”:(上下文)=>MyHomePage(
标题:“演示”,
),
“第一个”:(上下文)=>OnboardingScreen(),
},
);
}
}

请阅读,如果有帮助,请将此标记为答案。谢谢。如果这对你有帮助,请把它标记为答案@索姆巴纳吉