(cordova) (inappbrowser) 让用户知道你正在准备他们的页面
(cordova) (inappbrowser) Let users know that you're getting their page ready
我有一个使用 cordova 和 InAppBrowser 构建的应用程序。我正在尝试显示 "loading spinner " 或 "loading message"(而不是在加载 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 中进行远程调试时是否遇到其他特定错误或其他问题?
您无法显示加载消息,因为如果您打开 Inappbrowser,您的应用程序将进入后台,因此 div <div id="status-message"></div>
将被隐藏。
var Ref;
Ref = window.open('http://www.example.com', '_blank', 'location=no,toolbar=no');
Ref.addEventListener('loadstart', inAppBrowserbLoadStart);
Ref.addEventListener('loadstop', inAppBrowserbLoadStop);
Ref.addEventListener('loaderror', inAppBrowserbLoadError);
Ref.addEventListener('exit', inAppBrowserbClose);
function inAppBrowserbLoadStart(event) {
navigator.notification.activityStart("Please Wait", "Its loading....");
alert(event.type + ' - ' + event.url);
}
function inAppBrowserbLoadStop(event) {
navigator.notification.activityStop();
alert(event.type + ' - ' + event.url);
}
function inAppBrowserbLoadError(event) {
navigator.notification.activityStop();
alert(event.type + ' - ' + event.message);
}
function inAppBrowserbClose(event) {
Ref.removeEventListener('loadstart', iabLoadStart);
Ref.removeEventListener('loadstop', iabLoadStop);
Ref.removeEventListener('loaderror', iabLoadError);
Ref.removeEventListener('exit', iabClose);
}
我有一个使用 cordova 和 InAppBrowser 构建的应用程序。我正在尝试显示 "loading spinner " 或 "loading message"(而不是在加载 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 中进行远程调试时是否遇到其他特定错误或其他问题?
您无法显示加载消息,因为如果您打开 Inappbrowser,您的应用程序将进入后台,因此 div <div id="status-message"></div>
将被隐藏。
var Ref;
Ref = window.open('http://www.example.com', '_blank', 'location=no,toolbar=no');
Ref.addEventListener('loadstart', inAppBrowserbLoadStart);
Ref.addEventListener('loadstop', inAppBrowserbLoadStop);
Ref.addEventListener('loaderror', inAppBrowserbLoadError);
Ref.addEventListener('exit', inAppBrowserbClose);
function inAppBrowserbLoadStart(event) {
navigator.notification.activityStart("Please Wait", "Its loading....");
alert(event.type + ' - ' + event.url);
}
function inAppBrowserbLoadStop(event) {
navigator.notification.activityStop();
alert(event.type + ' - ' + event.url);
}
function inAppBrowserbLoadError(event) {
navigator.notification.activityStop();
alert(event.type + ' - ' + event.message);
}
function inAppBrowserbClose(event) {
Ref.removeEventListener('loadstart', iabLoadStart);
Ref.removeEventListener('loadstop', iabLoadStop);
Ref.removeEventListener('loaderror', iabLoadError);
Ref.removeEventListener('exit', iabClose);
}