js调用API学习

这周好多课,好多课程设计,等这几周度过了就可安心学习web了,这周就是看了一下js调用百度API地图控件的问题,查找了一些资料学习。

[html]  view plain  copy
 print ?
  1. <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=XXXXXXXXXXXXX">script>`<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=XXXXXXXXXXXXX">script>`  

上面这段代码执行完后百度会返回一段代码并插入到你的DOM中执行
[html]  view plain  copy
 print ?
  1. <script>  
  2.         (function() {  
  3.                 window.BMap_loadScriptTime = (new Date).getTime();  
  4.                 document.write('<script type="text/javascript" src="http://api.map.baidu.com/getscript?v=2.0&ak=XXXXXXXXXXX&services=&t=20160513110936">script>');})();  
  5.     script>  


首先记得引入百度api请求脚本,ak要换上自己的
[html]  view plain  copy
 print ?
  1. var setCookie = function(name, value) {  
  2.             var Days = 30;  
  3.             var exp = new Date();  
  4.             exp.setTime(exp.getTime() + Days * 24 * 60 * 60 * 1000);  
  5.             document.cookie = name + "=" + escape(value) + ";expires=" + exp.toGMTString();  
  6.         };  
  7.         var geolocation = new BMap.Geolocation();  
  8.         //弹出地理授权  
  9.         geolocation.getCurrentPosition(function(r) {  
  10.                 if (this.getStatus() == BMAP_STATUS_SUCCESS) {  
  11.                     alert('定位成功');  
  12.                     console.log(r.point);  
  13.                 } else {  
  14.                     alert("baidu return failed");  
  15.                 }  
  16.             },  
  17.             //获取失败时候的回调  
  18.             function(r) {  
  19.                 console.log(r);  
  20.                 alert('定位失败');  
  21.                 return {  
  22.                     //设置高精度  
  23.                     enableHighAccuracy: true  
  24.                 };  
  25.             }  
  26.         );  

在这个函数执行的时候,经过测试其实不管你是否允许地理位置的授权,都能获取到你的定位位置,只不过不授权时候获取的应该是IP地址的定位,授权是精确的GPS定位而已

所以这里的问题在于如果是这样的话,那在任何一段Javascript脚本中执行上述代码,用户在知道弹出询问是否允许获取地理位置授权这个提示之后,不管是否允许都能获取到使用者的定位的

这里还要注意几个地方就是geolocation是HTML5的东西,一般移动端支持都比较好的,用到的时候最好判断一下浏览器是否支持
[html]  view plain  copy
 print ?
  1. if ("geolocation" in navigator) {  
  2.                             alert("支持geolocation");  
  3.                         } else {  
  4.                             alert("不支持geolocation");  
  5.                         }  

还有百度geolocation.getCurrentPosition()这个函数里面的第一个参数是回调成功后执行的,第二个参数是回调后失败执行的,我看官网的地址貌似没有写明白第二个参数是可以传一个对象或者匿名函数进去,所以导致很多人不知道getCurrentPosition失效的时候怎么捕捉到这个失败的回调,我上面的例子就是传入一个失败时候要执行回调函数,让后面代码能顺利执行下去


如果确实因为各种原因而获取不到回调,建议这里加个定时器比较保险,免得program在这里白白被卡死
[html]  view plain  copy
 print ?
  1. setTimeout(function() {  
  2.             alert("获取超时");  
  3.             setCookie("longitude", '113.333333');  
  4.             setCookie("latitude", '23.333333');  
  5.             setCookie("city", 'autumnswind');  
  6.             setCookie("cityCode", '543210');  
  7.             load();  
  8.         }, 4000)  

其实百度的Geolocation跟HTML5 Geolocation(地理定位)也是非常相似的,看下面的例子
[html]  view plain  copy
 print ?
  1. >  
  2. <html>  
  3. <meta charset="UTF-8">  
  4. <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0,user-scalable=no">  
  5. <body>  
  6.         <p id="demo">点击按钮获取您当前坐标(可能需要比较长的时间获取):p>  
  7.         <button onclick="getLocation()">点我button>  
  8.         <div id="mapholder">div>  
  9.         <script>var x = document.getElementById("demo");  
  10.   
  11.   
  12. function getLocation() {  
  13.     if (navigator.geolocation) {  
  14.         navigator.geolocation.getCurrentPosition(showPosition, showError);  
  15.     } else {  
  16.         x.innerHTML = "该浏览器不支持获取地理位置。";  
  17.     }  
  18. }  
  19.   
  20.   
  21. function showPosition(position) {  
  22.     var latlon = position.coords.latitude + "," + position.coords.longitude;  
  23.     var img_url = "http://maps.googleapis.com/maps/api/staticmap?center=" + latlon + "&zoom=14&size=400x300&sensor=false";  
  24.     document.getElementById("mapholder").innerHTML = " + img_url + "'>";  
  25. }  
  26.   
  27.   
  28. function showError(error) {  
  29.     console.log(error);  
  30.     switch (error.code) {  
  31.         case error.PERMISSION_DENIED:  
  32.             x.innerHTML = "用户拒绝对获取地理位置的请求。"  
  33.             break;  
  34.         case error.POSITION_UNAVAILABLE:  
  35.             x.innerHTML = "位置信息是不可用的。"  
  36.             break;  
  37.         case error.TIMEOUT:  
  38.             x.innerHTML = "请求用户地理位置超时。"  
  39.             break;  
  40.         case error.UNKNOWN_ERROR:  
  41.             x.innerHTML = "未知错误。"  
  42.             break;  
  43.     }  
  44. }script>  
  45. body>  
  46. html>  


这里的navigator.geolocation.getCurrentPosition()也是传入两个函数,一个关于回调成功,一个关于回调失败的,测试的过程中发现一直返回给我
**位置信息是不可用的。**
上网查了原因,应该是:鉴于该特性可能侵犯用户的隐私,除非用户同意,否则用户位置信息是不可用的。还有可能是因为某些浏览器调用了谷歌的服务,所以这里会被卡了

你可能感兴趣的:(js调用API学习)