繁体   English   中英

在 Jetpack Compose 中动态显示 AndroidView

[英]Dynamically show AndroidView in Jetpack Compose

我正在构建一个包含 Web 视图列表的应用程序,我想根据条件显示 webview。 由于 Jetpack Compose 不支持 webview,我使用AndroidView使用原生的 WebView。

for (tab in vm.tabs) {
    if (tab.tabId == vm.currentTab.tabId) {
        AndroidView(
            factory = {
                WebView(it).apply {
                    settings.javaScriptEnabled = true
                    webChromeClient = WebChromeClient()
                    webViewClient = WebViewClient()
                    loadUrl(tab.url)
                }
            },
            modifier = Modifier.fillMaxSize()
        )
    }
}

我用谷歌搜索,发现AndroidView只会初始化一次,并且会在重组时调用更新。 我不想更新单个 webview。我只想为每个匹配条件显示一个全新的 webview。

我怎样才能做到这一点?

您可以使用 Google 的Accompanist ,这是一个提供围绕 Android 的 WebView 的 Jetpack Compose 包装器的库。

简单的例子

for (tab in vm.tabs) {
    if (tab.tabId == vm.currentTab.tabId) {
        val state = rememberWebViewState(tab.url)
        WebView(
            state,
            Modifier,
            onCreated = {
                it.settings.javaScriptEnabled = true
                //...
            }
        )
        if (state.isLoading) {
            CircularProgressIndicator()
        }
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM