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动画之流彩文字效果+图片模糊效果+边框伸展效果实现代码合集
Aug 18 HTML / CSS
浅析与CSS3的loading动画加载相关的transition优化
May 18 HTML / CSS
使用CSS3实现多列布局与多背景的技巧
Feb 29 HTML / CSS
Grid 宫格常用布局的实现
Jan 10 HTML / CSS
通过css3的filter滤镜改变png图片的颜色的示例代码
May 06 HTML / CSS
css3实现二维码扫描特效的示例
Oct 29 HTML / CSS
利用纯html5绘制出来的一款非常漂亮的时钟
Jan 04 HTML / CSS
HTML5拖拽的简单实例
May 30 HTML / CSS
浅谈HTML5中dialog元素尝鲜
Oct 15 HTML / CSS
Html5新增了哪些功能
Apr 16 HTML / CSS
css3 文字断裂效果
Apr 22 HTML / CSS
分享几个实用的CSS代码块
Jun 10 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
Notice: Undefined index: page in E:\PHP\test.php on line 14
2010/11/02 PHP
浅析SVN常见问题及解决方法
2013/06/21 PHP
成为好程序员必须避免的5个坏习惯
2014/07/04 PHP
JAVASCRIPT IE 与 FF中兼容问题小结
2009/02/18 Javascript
JS Date函数整理方便使用
2013/10/23 Javascript
JavaScript利用正则表达式去除日期中的“-”
2014/07/01 Javascript
利用jquery和BootStrap实现动态滚动条效果
2018/12/03 jQuery
jQuery实现带3D切割效果的轮播图功能示例【附源码下载】
2019/04/04 jQuery
使用vscode快速建立vue模板过程详解
2019/10/10 Javascript
js实现简单放大镜效果
2020/03/07 Javascript
各种Python库安装包下载地址与安装过程详细介绍(Windows版)
2016/11/02 Python
Python pygorithm模块用法示例【常见算法测试】
2018/08/16 Python
修改默认的pip版本为对应python2.7的方法
2018/11/06 Python
实例讲解Python中浮点型的基本内容
2019/02/11 Python
解析Python3中的Import
2019/10/13 Python
python函数装饰器之带参数的函数和带参数的装饰器用法示例
2019/11/06 Python
基于python实现把图片转换成素描
2019/11/13 Python
PyCharm无法识别PyQt5的2种解决方法,ModuleNotFoundError: No module named 'pyqt5'
2020/02/17 Python
python else语句在循环中的运用详解
2020/07/06 Python
解决Windows下python和pip命令无法使用的问题
2020/08/31 Python
css实例教程 一款纯css3实现的超炫动画背画特效
2014/11/05 HTML / CSS
详解CSS3选择器:nth-child和:nth-of-type之间的差异
2017/09/18 HTML / CSS
俄罗斯运动鞋商店:Sneakerhead
2018/05/10 全球购物
工地资料员岗位职责
2013/12/31 职场文书
2014的自我评价
2014/01/13 职场文书
银行实习生的自我评价
2014/01/13 职场文书
优秀医生事迹材料
2014/02/12 职场文书
论文评语大全
2014/04/29 职场文书
食品安全工作方案
2014/05/07 职场文书
学校创先争优活动总结
2014/08/28 职场文书
学生夜不归宿检讨书
2014/09/23 职场文书
党员群众路线教育实践活动学习笔记
2014/11/05 职场文书
个人党性分析材料
2014/12/19 职场文书
部门优秀员工推荐信
2015/03/24 职场文书
掌握一个领域知识,高效学习必备方法
2019/08/08 职场文书
Python简易开发之制作计算器
2022/04/28 Python