0

我已经使用查询移动和 html5 创建了一个 Web 应用程序,目前,我的 JS 都没有在应用程序中执行。

JS 在 Android WebView 上启用,因为 Jquery mobile 可以为库执行 JS,但不能在 android 设备上运行。

它在 iOS 模拟器和网络浏览器上运行良好,所以我想知道是否有某种隐藏的设置/实现我需要为 android 处理?

这是我从使用电话间隙输出的简单对话框 html 上的 onClick 事件中收到的错误

07-15 09:25:00.621: E/Web Console(2992): Uncaught ReferenceError: uploadTrue is not defined at file:///android_asset/www/itemDetailCarHire.html:2

这是启动执行 onClick 的对话框的 itemDetailCarHire html。

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
<title></title>
<link href="src/jquery.mobile-1.3.1.min.css" rel="stylesheet" type="text/css"/>
<link rel="stylesheet" href="src/jquery.mobile.iscrollview.css" />
<link rel="stylesheet" href="src/jquery.mobile.iscrollview-pull.css" />
<script src="src/jquery-1.9.1.min.js" type="text/javascript"></script>
<script src="src/jquery.mobile-1.3.1.min.js" type="text/javascript"></script>

<script src="src/iscroll.js"></script>
<script src="src/jquery.mobile.iscrollview.js"></script>
<script src="src/script/itemDetailCarHire.js"></script>

  <link rel="stylesheet" href="src/jquery.ui.datepicker.mobile.css" /> 
  <script src="src/jquery.ui.datepicker.js"></script>
  <script src="src/jquery.ui.datepicker.mobile.js"></script>


</head>

<body>
<div data-role="page" id="fields">
  <div data-role="header" data-position="fixed" data-theme="b" data-tap-toggle="false" data-transition="none" > <a href="" onclick="history.back(-1); return false;">Back</a>
    <h1>New Claim</h1>
  </div>
  <div data-role="content">
    <ul class="ui-li" data-role="listview" id="claimProfileListView" data-inset="true"  data-scroll="true">

        <h3>Original Receipt:</h3>
        <div data-role="fieldcontain"> <a href="uploadRecieptDialog.html" data-role="button" data-rel="dialog">Upload Reciept</a> </div>
      </li>

    </ul>
    <div data-role="navbar">
      <ul>
        <li><a href="claimItemSummary.html" data-theme="b">Save Claim Item</a></li>
      </ul>
    </div>
  </div>
</div>
</body>
</html>

当用户单击原始收据组件时,它将正确显示名为 uploadRecieptDialog.html 的对话框,其代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
<title></title>
<link href="src/jquery.mobile-1.3.1.min.css" rel="stylesheet" type="text/css"/>
<link rel="stylesheet" href="src/jquery.mobile.iscrollview.css" />
<link rel="stylesheet" href="src/jquery.mobile.iscrollview-pull.css" /> 
<script src="src/jquery-1.9.1.min.js" type="text/javascript"></script>
<script src="src/jquery.mobile-1.3.1.min.js" type="text/javascript"></script>
<script src="src/iscroll.js"></script>
<script src="src/jquery.mobile.iscrollview.js"></script> 


</head>
<body>
<div data-role="page" id="page">

<div data-role="header"  data-theme="b"  data-position="fixed" >

        <h1>Upload Reciept</h1>

    </div>
  <div data-role="content">
  <p>Click the button below to select and upload your Reciept</p>
    <h3><a onclick="uploadTrue();" data-role="button" data-theme="c" >upload Reciept</a></h3>

    <div data-role="footer" data-position="fixed" data-theme="b" >

    </div>
  </div>
</div>
</body>
</html>

这是 updateDetailCarHire.JS

function uploadTrue(){
        alert("upload true");

        //load previous page
        history.back(-1); return false;
        alert("UPLOADED");

    }

如您所见,一个简单的 JS 显示一条警告消息并返回到上一个屏幕。在 iOS 模拟器和 chrome/safari 桌面网络浏览器上,它可以工作!

4

1 回答 1

0

我猜你的 Javascript 没有执行,因为你的历史命令有问题。

在这里检查:在 Cordova 1.8.1 - Android history.back() not working

并且可能:为什么是 javascript:history.go(-1); 不在移动设备上工作?

尝试使用history.back();

编辑:我没有看到 updateDetailCarHire.JS 包含在任何这些 HTML 页面中。

于 2013-07-15T08:42:22.723 回答