gpt4 book ai didi

javascript - (cordova) (inappbrowser) 让用户知道你正在准备他们的页面

转载 作者:行者123 更新时间:2023-11-29 15:42:07 24 4
gpt4 key购买 nike

我有一个使用 cordova 和 InAppBrowser 构建的应用程序。我正在尝试显示“正在加载微调器”或“正在加载消息”(而不是在加载 inappbrowser 时出现空白页面),我尝试这样做但它不起作用,这是我的 app.js 代码:

$(document).ready(function() {
document.addEventListener("deviceready", onDeviceReady, false);
});

var ref;

function onDeviceReady() {

try {
ref = cordova.InAppBrowser.open('https://cordova.apache.org', '_blank', 'location=no');
ref.addEventListener('loadstart', loadStartCallBack);
ref.addEventListener("exit", onBackButton, false);
}
catch(err) {
alert("Plugin Error - " + err.message);
}



function onBackButton(e) {
navigator.app.exitApp();
}

function loadStartCallBack() {

$('#status-message').text("loading please wait ...");

}
}

这是我的 index.html 代码:

<!DOCTYPE html>

<html>
<head>
<meta name="format-detection" >
<meta name="msapplication-tap-highlight" content="no">
<meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
<title>InApp Browser</title>

</head>
<body>
<script type="text/javascript">
navigator.splashscreen.show();
</script>
<div id="status-message"></div>
<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript" src="cordova.js"></script>
<script type="text/javascript" src="js/app.js"></script>
</body>
</html>

最佳答案

loadstop callback应该为您解决问题。

记得在 browser.open 方法中添加属性 hidden=yes 作为第三个参数,否则浏览器将始终可见,您将看不到加载留言:

cordova.InAppBrowser.open('https://cordova.apache.org', '_blank', 'location=no,hidden=yes');

最后你的代码应该是这样的:

<script>
var ref;

function onDeviceReady() {
try {
ref = cordova.InAppBrowser.open('https://cordova.apache.org', '_blank', 'location=no,hidden=yes');
ref.addEventListener('loadstart', loadStartCallBack);
ref.addEventListener("loadstop", loadEndCallback, false);
ref.addEventListener("exit", onBackButton, false);
} catch (err) {
alert("Plugin Error - " + err.message);
}

function onBackButton(e) {
navigator.app.exitApp();
}

function loadStartCallBack() {
$('#status-message').text("loading please wait ...");
}

function loadEndCallback(){
alert("Your page has been loaded, showing ...");
$('#status-message').text("");
ref.show();
}
}

document.addEventListener("deviceready", onDeviceReady, false);
</script>

在 chrome 中进行远程调试时,您是否遇到了其他特定错误或其他问题?

关于javascript - (cordova) (inappbrowser) 让用户知道你正在准备他们的页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38655168/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com