6

我发现可组合屏幕在从 Navhost 导航期间多次重新组合 compose 以下示例显示了我如何将导航与日志集成以确定函数被调用的次数,

internal sealed class Screen(val route: String) {
  object Splash : Screen("splash")
  object Login : Screen("login")
  object Credentials : Screen("credentials/{type}") {
    fun createRoute(type: String) = "credentials/$type"
  }
}

@Composable
fun HostNavGraph(
  modifier: Modifier = Modifier,
  startDestination: String = Splash.route,
) {
  val navController = rememberNavController()
  val vm: CredentialsViewModel = getViewModel()
  NavHost(navController = navController, startDestination = startDestination, modifier = modifier) {
    composable(route = Splash.route) {
      Log.e("composable", " Splash")
      SplashScreen(openLogin = {
        navController.navigate(Login.route)
      }, openRegistration = { type ->
        navController.navigate(Credentials.createRoute(type))
      })
    }
    composable(route = Login.route) {
      Log.e("composable", " Login")
      val context = LocalContext.current
      LoginScreen(openRegistration = { type ->
        navController.navigate(Credentials.createRoute(type))
        {
          popUpTo(Splash.route) { inclusive = false }
        }

      }, openWebView = {
        openWebView(context, it)
      })
    }
    //..
  }
}

在运行代码之后,这是在打开 Splash 一次然后打开 LoginScreen 之后导航的行为方式

15:05:14 E/composable:  Splash 
15:05:14 E/composable:  Splash 
15:05:25 E/composable:  Splash 
15:05:25 E/composable:  Login  
15:05:26 E/composable:  Splash 
15:05:26 E/composable:  Login  
15:05:26 E/composable:  Login  

我还尝试了一些带有 Navigation compose 的 Google 示例,它的行为方式相同,所以这是预期的行为吗?还是一个错误
navigation_version = '2.4.0-alpha08'

4

2 回答 2

3

我不确定,但我认为 NavHost 有一个内置动画,只要有过渡。并且对于动画,重组可能会像每一帧一样频繁地发生。

可组合函数可能会非常频繁地运行,就像动画的每一帧一样频繁。

** Android 撰写

于 2021-09-26T13:56:57.410 回答
1

这是 Android Compose 工作方式的一般性质。每当它发现有必要时,可组合重组自身。阅读文档以获取更多详细信息。

于 2021-10-26T07:53:21.807 回答