zoukankan      html  css  js  c++  java
  • 原生js获取手机定位信息

    <script type="text/javascript">
    function Location() {};

    Location.prototype.getLocation = function (callback) {
    var options = {
    enableHighAccuracy: true,
    maximumAge: 1000
    };
    this.callback = Object.prototype.toString.call(callback) == "[object Function]" ?
    callback :
    function (address) {
    alert(address.province + address.city);
    console.log("getocation(callbackFunction) 可获得定位信息对象");
    };
    var self = this;
    if (navigator.geolocation) {
    //浏览器支持geolocation
    navigator.geolocation.getCurrentPosition(function (position) {
    //经度
    var longitude = position.coords.longitude;
    //纬度
    var latitude = position.coords.latitude;
    self.loadMapApi(longitude, latitude);
    }, self.onError, options);
    } else {
    //浏览器不支持geolocation
    }
    };

    Location.prototype.loadMapApi = function (longitude, latitude) {
    var self = this;
    var oHead = document.getElementsByTagName('HEAD').item(0);
    var oScript = document.createElement("script");
    oScript.type = "text/javascript";
    oScript.src = "http://api.map.baidu.com/getscript?v=2.0&ak=A396783ee700cfdb9ba1df281ce36862&services=&t=20140930184510";
    oHead.appendChild(oScript);
    oScript.onload = function (date) {
    var point = new BMap.Point(longitude, latitude);
    var gc = new BMap.Geocoder();
    gc.getLocation(point, function (rs) {
    var addComp = rs.addressComponents;
    self.callback(addComp);
    });
    }
    };

    Location.prototype.onError = function (error) {
    switch (error.code) {
    case 1:
    alert("位置服务被拒绝");
    break;
    case 2:
    alert("暂时获取不到位置信息");
    break;
    case 3:
    alert("获取信息超时");
    break;
    case 4:
    alert("未知错误");
    break;
    }
    };

    //调用
    var local = new Location();
    local.getLocation(function (res) {
    //此处就是返回的地理位置信息
    console.log(res);
    //JSON.stringify(res),把返回的对象转为字符串了,自己根据需求截取下就好
    var resstr = JSON.stringify(res);
    alert(resstr);
    });
    </script>

  • 相关阅读:
    【BZOJ-4289】Tax 最短路 + 技巧建图
    【BZOJ-3895】取石子 记忆化搜索 + 博弈
    【BZOJ-4569】萌萌哒 ST表 + 并查集
    【BZOJ-3832】Rally 拓扑序 + 线段树 (神思路题!)
    【BZOJ-4213】贪吃蛇 有上下界的费用流
    【BZOJ-3122】随机数生成器 BSGS
    【BZOJ-2299】向量 裴蜀定理 + 最大公约数
    【BZOJ-1441】Min 裴蜀定理 + 最大公约数
    【BZOJ-2438】杀人游戏 Tarjan + 缩点 + 概率
    【BZOJ-4310】跳蚤 后缀数组 + ST表 + 二分
  • 原文地址:https://www.cnblogs.com/lwj820876312/p/9639610.html
Copyright © 2011-2022 走看看