使用原生js+百度地图api实现获取当前地理位置

在百度地图获取到自己的百度地图ak,填到ak的位置

<!DOCTYPE html>
<html lang="en">

<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</title>
</head>

<body>
    您目前在<p></p>
</body>
<script>
    //定义一个空的位置构造函数
    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
        }
    };
    //定义一个可以解析经纬度的方法,调用百度的api
    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=*****";
        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;
                console.log(addComp);
                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();
let defaultCity =     local.getLocation(function (res) {
    console.log(res);
        var str = ""
        for (i in res) {
            str = res[i] + str
        }
        console.log(str);
        var reg = /.+?(省|市|自治区|自治州|县|区)/g; // 省市区的正则
        city = str.match(reg)
        console.log(city[city.length-1]);

        document.querySelector("p").innerHTML = str;
    })
</script>

</html>

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 UniApp 中获取地理位置可以使用小程序的原生 API,具体步骤如下: 1. 引入权限声明:在 `manifest.json` 文件中,添加以下代码来声明获取地理位置的权限: ```json "permission": { "scope.userLocation": { "desc": "获取地理位置信息" } } ``` 2. 获取地理位置:在需要获取地理位置的页面或组件中,可以使用 `uni.getLocation` 方法来获取地理位置信息。示例代码如下: ```javascript uni.getLocation({ type: 'gcj02', success: function(res) { const latitude = res.latitude; // 纬度 const longitude = res.longitude; // 经度 } }); ``` `type` 参数指定了返回的坐标类型,可选值包括 `'wgs84'`、`'gcj02'` 和 `'bd09'`,其中 `'gcj02'` 是国测局坐标系,一般在国内使用。 3. 处理定位失败:在获取地理位置失败的情况下,可以在 `success` 回调函数中添加 `fail` 参数来处理失败情况。示例代码如下: ```javascript uni.getLocation({ type: 'gcj02', success: function(res) { const latitude = res.latitude; // 纬度 const longitude = res.longitude; // 经度 }, fail: function(err) { console.log(err); } }); ``` 注意:在使用 `uni.getLocation` 方法前,请确保已经声明了获取地理位置的权限,并且用户已经授权。如果用户未授权,则需要通过其他方式引导用户进行授权。 以上是获取地理位置的基本步骤,UniApp 还提供了其他与地理位置相关的 API,如获取地理位置的逆地址解析、监听位置变化等。具体的使用方法可以参考 UniApp 的官方文档。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值