Nativescript Webview 和 Android 返回按钮

5

我在Nativescript中创建了一个只包含Webview的页面。以下是我的代码:

<Page xmlns="http://www.nativescript.org/tns.xsd" actionBarHidden="true">

    <WebView src="http://example.com/" />

</Page>

以下是 JavaScript 代码:

import * as webViewModule from "tns-core-modules/ui/web-view";

let webView = new webViewModule.WebView();

webView.on(webViewModule.WebView.loadFinishedEvent, function (args: webViewModule.LoadEventData) {
    let message;
    if (!args.error) {
        message = "WebView finished loading " + args.url;
    }
    else {
        message = "Error loading " + args.url + ": " + args.error;
    }

});
webView.src = "http://example.com/";

一切正常,直到我按下 android 返回按钮。然后,在导航到 webview 中的最后一页之前,应用程序就退出了。当我再次从应用程序菜单中打开它(返回到相同的最小化应用程序),它会重新加载 webview 内容而不是保存其状态。

需要帮助,感激不尽。

1个回答

9

您需要像这样处理Android硬按键:

首先导入依赖项:

import { AndroidApplication, AndroidActivityBackPressedEventData } from "application";
import * as application from "application";

然后添加这段代码:
application.android.on(AndroidApplication.activityBackPressedEvent, (data: AndroidActivityBackPressedEventData) => {
  data.cancel = true; // prevents default back button behavior
  console.log("webview can go back " + webView.canGoBack);
  if (webView.canGoBack) //if webview can go back
      webView.goBack();
  else
      this.router.backToPreviousPage();
});

iOS怎么样? - Xsmael
1
iOS没有硬返回按钮。所以不用担心 :) - Deepika
当您导航时,“软”返回按钮会自动出现吗?我问这个问题是因为我正在开发一个需要禁用操作栏的应用程序。 - Xsmael
你可以处理。你可以隐藏操作栏。 - Deepika
1
对于 HTML 页面,如果你想在 iOS 上有操作栏但没有返回按钮:<NavigationButton *ngIf="!isAndroidFlag" visibility="collapsed"></NavigationButton> - Deepika
显示剩余2条评论

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接