Javascript 在Android上使用PhoneGap进行地理定位仅在index.html上有效

Javascript 在Android上使用PhoneGap进行地理定位仅在index.html上有效,javascript,android,html,cordova,geolocation,Javascript,Android,Html,Cordova,Geolocation,我试图使用PhoneGap API文档使用地理定位,地理定位在index.html上工作 但是,当我试图在不同的页面中使用相同的函数时,它不起作用 这是我正在使用的JS 这是我用来进入另一页的按钮 我也在使用jquerymobile <a href="test.html" data-theme="b" data-icon="plus">Add category</a></li> 下面是test.html的标题 <meta charset="ut

我试图使用PhoneGap API文档使用地理定位,地理定位在index.html上工作 但是,当我试图在不同的页面中使用相同的函数时,它不起作用

这是我正在使用的JS

这是我用来进入另一页的按钮

我也在使用jquerymobile

 <a href="test.html" data-theme="b" data-icon="plus">Add category</a></li>

下面是test.html的标题

<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title></title>
<link rel="stylesheet" href="styles/jquery.mobile-1.1.0.min.css" />
<link rel="stylesheet" href="styles/jquery.mobile.structure-1.1.0.min.css" />
<link rel="stylesheet" href="styles/jquery.mobile.theme-1.1.0.min.css" />
<link rel="stylesheet" href="styles/my.css" />
<script src="scripts/jquery-1.7.2.min.js"></script>
<script src="scripts/jquery.mobile-1.1.0.min.js"></script>
<script src="scripts/cordova-1.8.1.js"></script>
<script>

    // Wait for Cordova to load
    //
    document.addEventListener("deviceready", onDeviceReady, false);

    var watchID = null;

    // Cordova is ready
    //
    function onDeviceReady() {
        // Throw an error if no update is received every 30 seconds
        var options = { timeout: 10000 };
        watchID = navigator.geolocation.watchPosition(onSuccess, onError, options);
    }

    // onSuccess Geolocation
    //
    function onSuccess(position) {
        var element = document.getElementById('geolocation');
        element.innerHTML = 'Latitude: ' + position.coords.latitude + '<br />' +
                        'Longitude: ' + position.coords.longitude + '<br />' +
                        '<hr />' + element.innerHTML;
    }

    // onError Callback receives a PositionError object
    //
    function onError(error) {
        alert('code: ' + error.code + '\n' +
          'message: ' + error.message + '\n');
    }
</script>

//等待Cordova加载
//
文件。添加的监听器(“deviceready”,OnDeviceraddy,false);
var-watchID=null;
//科尔多瓦准备好了
//
函数ondevicerady(){
//如果每30秒未收到更新,则引发错误
var选项={timeout:10000};
watchID=navigator.geolocation.watchPosition(onSuccess、onError、options);
}
//成功地理定位
//
成功时的功能(位置){
var element=document.getElementById('geolocation');
element.innerHTML='Latitude:'+position.coords.Latitude+'
'+ '经度:'+position.coords.Longitude+'
'+ “
”+element.innerHTML; } //OneError回调接收PositionError对象 // 函数onError(错误){ 警报('code:'+error.code+'\n'+ '消息:'+error.message+'\n'); }
问题是我没有将cordova.jar文件加载到我的项目中,这就是它不起作用的原因

首先在Android清单中授予权限:

      android.permission.ACCESS_FINE_LOCATION
      android.permission.ACCESS_LOCATION_EXTRA_COMMANDS
      android.permission.ACCESS_COARSE_LOCATION
然后复制cordova-1.8.1.js并在资产的www子文件夹中创建index.html,然后将cordova-1.8.1.jar复制到libs,然后使用cordova-1.8.1.jar配置构建路径

然后创建res-->xml并复制插件(从先前下载的PhoneGap 1.8.1)


然后运行应用程序。您肯定会得到输出。

Plz张贴test.html的标题