JS获取经纬度并根据经纬度得到城市信息简单示例

 更新时间:2023年11月03日 08:30:59   作者:Cc琎  
前端时间刚好使用了百度地图的js api定位获取用户当前经纬度并获取当前详细位置的功能,为了方便下次找起来方便一些自己在这里记录一下,这篇文章主要给大家介绍了关于JS获取经纬度并根据经纬度得到城市信息的相关资料,需要的朋友可以参考下

前言

在JavaScript中,获取经纬度通常需要使用定位服务,比如HTML5的Geolocation API。然而拿到坐标后,将经纬度转换为城市信息,则需要使用逆地理编码服务接口,比如百度或者高德的 API, 但是他们收费都很高, 我们可以使用一些便宜的接口, 效果一样的。

以下是一个简单的示例:

一、获取经纬度

首先,你需要使用Geolocation API获取用户的经纬度。这需要用户的许可,所以它是一个异步操作。以下是如何获取经纬度的代码:

navigator.geolocation.getCurrentPosition(function(position) {
    var lat = position.coords.latitude;
    var lon = position.coords.longitude;
    console.log("Latitude: " + lat);
    console.log("Longitude: " + lon);
}, function(error) {
    console.log("Error occurred. Error code: " + error.code);
    // error.code 可以是:0, 1,或2
});

二、根据经纬度获取城市信息

然后,你可以使用易客云API将经纬度转换为城市信息。以下是使用此API的示例代码:

<!-- 此示例需要注册api账号
    https://yikeapi.com/index/geocode
-->
<!DOCTYPE html>
<html lang="zh-CN" style="height: 100%">
    <head>
        <meta charset="utf-8">
    </head>
    <body style="height: 100%; margin: 0">
        <div id="container" style="height: 100%">
        </div>
        <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.min.js">
        </script>
        <script type="text/javascript">
            $.get('http://apia.yikeapi.com/geocode/?appid=43656176&appsecret=I42og6Lm&output=json&location=116.437039,39.999664',
            function(res) {
                console.log(res);
                var json = JSON.parse(res);
                if (json.errcode == 0) {
                    console.log('当前所在城市:' + json.regeocode.addressComponent.district);
                }
            });
        </script>
    </body>

</html>

输出结果

{“errcode”:0,“errmsg”:“success”,“nums”:147,“regeocode”:{“addressComponent”:{“province”:“北京市”,“city”:“北京市”,“district”:“朝阳区”,“adcode”:“110105”}}}
当前所在城市:朝阳区

易客云的逆地理编码接口返回的json结构和百度高德一模一样, 但是只支持区县级, 每日5万次级的仅需要三位数, 比5万便宜多啦🌶, 如果不是街道级定位要求, 那可以用这个

接口返回JSON

{
    "errcode":0,
    "errmsg":"success",
    "nums":140,
    "regeocode":{
        "addressComponent":{
            "province":"北京市",
            "city":"北京市",
            "district":"朝阳区",
            "adcode":"110105"
        }
    }
}

另外,也请注意,上述操作需要用户允许浏览器访问地理位置信息,这在某些浏览器设置或用户隐私设置中可能被禁用或受限。

总结

到此这篇关于JS获取经纬度并根据经纬度得到城市信息的文章就介绍到这了,更多相关JS获取经纬度内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • js将long日期格式转换为标准日期格式实现思路

    js将long日期格式转换为标准日期格式实现思路

    本文为大家详细介绍下js将long日期格式转换为标准日期格式,感兴趣的朋友可以参考下哈,希望可以帮助到你
    2013-04-04
  • Javascript实现鼠标移入方向感知

    Javascript实现鼠标移入方向感知

    这篇文章主要为大家详细介绍了Javascript实现鼠标移入方向感知,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • Javascript闭包实例详解

    Javascript闭包实例详解

    闭包就是函数的局部变量集合,只是这些局部变量在函数返回后会继续存在,本文通过代码实例给大家介绍javascript闭包,对javascipt闭包相关知识感兴趣的朋友一起学习吧
    2015-11-11
  • JS仿百度自动下拉框模糊匹配提示

    JS仿百度自动下拉框模糊匹配提示

    这篇文章主要介绍了JS仿百度自动下拉框模糊匹配提示 的相关资料,需要的朋友可以参考下
    2016-07-07
  • 前端发布缓存导致白屏几种解决方案总结

    前端发布缓存导致白屏几种解决方案总结

    这篇文章主要介绍了前端发布缓存导致白屏的几种解决方案,文章还介绍了Jenkins发布流程优化和使用版本号方案,以减少发布缓存问题,每种方案都有其优缺点,需要根据实际情况进行选择和调整,需要的朋友可以参考下
    2025-04-04
  • 微信小程序vant 输入框问题处理方案

    微信小程序vant 输入框问题处理方案

    这篇文章主要介绍了微信小程序vant输入框问题,本文给大家分享完美解决方案,结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-09-09
  • javascript前端埋点上报的几种方式

    javascript前端埋点上报的几种方式

    本文将介绍前端埋点上报的几种常见方式,并详细阐述如何在项目中运用这些方式进行数据上报,以帮助开发者更好地进行数据收集和分析,感兴趣的可以了解一下
    2023-11-11
  • Javascript基础教程之比较null和undefined值

    Javascript基础教程之比较null和undefined值

    这篇文章主要介绍了Javascript基础教程之比较null和undefined值的相关知识,非常不错,具有参考借鉴价值,感兴趣的朋友一起学习吧
    2016-05-05
  • JavaScript初学者应注意的七个细节小结

    JavaScript初学者应注意的七个细节小结

    每种语言都有它特别的地方,对于JavaScript来说,使用var就可以声明任意类型的变量,这门脚本语言看起来很简单,然而想要写出优雅的代码却是需要不断积累经验的
    2012-01-01
  • JS 实现10进制转换36进制的示例代码

    JS 实现10进制转换36进制的示例代码

    这篇文章主要介绍了JS实现10进制转换36进制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04

最新评论