Html5获取用户当前位置的几种方式


Posted in HTML / CSS onJanuary 18, 2022

前言

前段时间写到H5获取用户当前位置,百度了好多种办法都没实现,包括H5自带的方法,具体问题不知道出在哪里了,基本都是报错啥的,下面一起看看吧~

一、使用H5自带的获取位置

先使用navigator.geolocation判断浏览器是否支持,如果不支持就提示或者使用其他方法。

if(navigator.geolocation) {
      navigator.geolocation.getCurrentPosition((res)=> {
           console.log(res);//这里会返回经纬度,然后还要通过经纬度转换地区名称
      });
}

 总结
1、部分手机和浏览器不太支持这个API,还会有警告报错,所以感觉这个API有点鸡肋,不太能用得上。
2、如果需要展示地区名称,还需要另外引入类似百度地图的第三方平台提供的js进行经纬度转换地区名称等。
3、浏览器地址必须是https的,不然不支持。

二、使用百度地图获取位置

1、在百度地图开发平台注册账号,并申请ak密钥
2、在页面中引用百度地图js,(vue项目就在index.html中引用)

<body>
    <div id="app"></div>
    <!-- built files will be auto injected -->
    <script type="text/javascript" src="https://api.map.baidu.com/api?v=2.0&ak=qI3333RVsdret2A9999VC858Q&s=1"></script>
 </body>

3、在页面中写入下面代码(可以直接返回经纬度和省市区名称等):

mounted() {            
            //获取当前城市
            var geolocation=new BMap.Geolocation();
            geolocation.getCurrentPosition(function(r){
                var city=r.address.city//返回当前城市
                that.currCity = city;
            })
},

Html5获取用户当前位置的几种方式 

总结
这样手机上就会有弹框提示获取位置啦,这个方法可以适用于微信浏览器和普通浏览器,基本没有问题,没有bug,尝试起来!就是需要公司去申请ak会比较麻烦,并且也需要https才可以使用,相对于第一个还是很好用很有效果的。

三、微信js-sdk自带的API

登录微信平台获取appid和秘钥

配置服务器信息,和js接口安全域名、网页授权域名等

把配置信息文件.txt放到配置的服务器下面

查看所有的接口权限,是否有获取用户地理位置

通过调接口的方式获取时间戳,签名等

wx.ready(function () 
{
    wx.checkJsApi(
    {
        jsApiList : ['getLocation'],
        success : function (res) 
        {
            if (!res.checkResult.getLocation) {
                alert('暂不支持获取地理位置接口,请升级微信版本!');
                return;
            }
        }
    }) wx.getLocation(
    {
        success : function (res) 
        {
            console.log(res)//地理位置信息都在这里
        },
        cancel : function (res) 
        {
            alert('用户拒绝授权位置信息!');
        }
    })
})

总结

一共列举的三种H5获取地理位置的方式,如果不是在公众号中非必要的情况下还是比较推荐使用类似百度地图这样的第三方获取,比较方便,并且百试百灵,一开始不想用第三方的东西就打算用H5自带的API弄了好久试了好多个手机和浏览器都没成功,真是心碎。

到此这篇关于Html5获取用户当前位置的几种方式的文章就介绍到这了,更多相关Html5获取用户当前位置内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
实例讲解CSS3中的box-flex弹性盒属性布局
Jun 09 HTML / CSS
详解利用css3的var()实现运行时改变scss的变量值
Mar 02 HTML / CSS
详解HTML5中的标签
Jun 19 HTML / CSS
使用HTML5 Canvas绘制直线或折线等线条的方法讲解
Mar 14 HTML / CSS
HTML5 Canvas阴影使用方法实例演示
Aug 02 HTML / CSS
详解HTML5中rel属性的prefetch预加载功能使用
May 06 HTML / CSS
h5调用摄像头的实现方法
Jun 01 HTML / CSS
浅谈h5自定义audio(问题及解决)
Aug 19 HTML / CSS
html5超简单的localStorage实现记住密码的功能实现
Sep 07 HTML / CSS
JavaScript+Canvas实现自定义画板的示例代码
May 13 HTML / CSS
Canvas波浪花环的示例代码
Aug 21 HTML / CSS
html+css实现环绕倒影加载特效
Jul 07 HTML / CSS
html粘性页脚的具体使用
Jan 18 #HTML / CSS
CSS三大特性继承性、层叠性和优先级详解
Jan 18 #HTML / CSS
使用CSS设置滚动条样式
在CSS中使用when/else的方法
Jan 18 #HTML / CSS
CSS使用伪类控制边框长度的方法
浅谈css实现背景颜色半透明的两种方法
Dec 06 #HTML / CSS
HTML怎么设置下划线?html文字加下划线方法
Dec 06 #HTML / CSS
You might like
php输出xml格式字符串(用的这个)
2012/07/12 PHP
PHP模拟登陆163邮箱发邮件及获取通讯录列表的方法
2015/03/07 PHP
PHP脚本监控Nginx 502错误并自动重启php-fpm
2015/05/13 PHP
PHP编程中的__clone()方法使用详解
2015/11/27 PHP
Zend Framework分页类用法详解
2016/03/22 PHP
laravel 实现设置时区的简单方法
2019/10/10 PHP
PHP扩展安装方法步骤解析
2020/11/24 PHP
js正文内容高亮效果的实现方法
2013/06/30 Javascript
javascript代码运行不出来执行错误的可能情况整理
2013/10/18 Javascript
Javascript遍历table中的元素示例代码
2014/07/08 Javascript
JavaScript中的Truthy和Falsy介绍
2015/01/01 Javascript
javascript学习笔记整理(概述、变量、数据类型简介)
2015/10/25 Javascript
有关JavaScript中call()和apply() 的一些理解
2016/05/20 Javascript
简单谈谈Javascript函数中的arguments
2017/02/09 Javascript
Angular2利用组件与指令实现图片轮播组件
2017/03/27 Javascript
yarn的使用与升级Node.js的方法详解
2017/06/04 Javascript
vue2中filter()的实现代码
2017/07/09 Javascript
利用Node.js了解与测量HTTP所花费的时间详解
2017/09/22 Javascript
EasyUI实现下拉框多选功能
2017/11/07 Javascript
Angular4.x通过路由守卫进行路由重定向实现根据条件跳转到相应的页面(推荐)
2018/05/10 Javascript
详解js根据百度地图提供经纬度计算两点距离
2019/05/13 Javascript
基于vue-draggable 实现三级拖动排序效果
2020/01/10 Javascript
jQuery实现移动端下拉展现新的内容回弹动画
2020/06/24 jQuery
vue实现抽屉弹窗效果
2020/11/15 Javascript
Python猫眼电影最近上映的电影票房信息
2020/09/18 Python
介绍一下Ruby的特点
2013/01/20 面试题
单位创先争优活动方案
2014/01/26 职场文书
母婴店促销方案
2014/03/05 职场文书
出国留学担保书
2014/05/20 职场文书
承诺书格式范文
2014/06/03 职场文书
医学求职自荐信
2014/06/21 职场文书
年度优秀员工获奖感言
2014/08/15 职场文书
运动会广播稿100字
2014/09/14 职场文书
病人家属写给医院的感谢信
2015/01/23 职场文书
python实现简单区块链结构
2021/04/25 Python
8g内存用python读取10文件_面试题-python 如何读取一个大于 10G 的txt文件?
2021/05/28 Python