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 相关文章推荐
CSS Grid布局教程之浏览器开启CSS Grid Layout汇总
Dec 30 HTML / CSS
基于html和CSS3制作酷炫的导航栏
Sep 23 HTML / CSS
CSS实现聊天气泡效果
Apr 26 HTML / CSS
html5指南-3.如何实现html元素拖拽功能
Jan 07 HTML / CSS
HTML5实现晶莹剔透的雨滴特效
May 14 HTML / CSS
html5+css3进度条倒计时动画特效代码【推荐】
Mar 08 HTML / CSS
HTML5页面音视频在微信和app下自动播放的实现方法
Oct 20 HTML / CSS
HTML5实现文件断点续传的方法
Jan 04 HTML / CSS
HTML5 Canvas 实现圆形进度条并显示数字百分比效果示例
Aug 18 HTML / CSS
前端实现打印图像功能
Aug 27 HTML / CSS
AmazeUI 平滑滚动效果的示例代码
Aug 20 HTML / CSS
浅析CSS在DevTools 中架构演变
Oct 05 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
基于mysql的论坛(4)
2006/10/09 PHP
解析PHP中常见的mongodb查询操作
2013/06/20 PHP
PHP制作用户注册系统
2015/10/23 PHP
javascript学习笔记--数字格式类型
2014/05/22 Javascript
Javascript前端UI框架Kit使用指南之kitjs的对话框组件
2014/11/28 Javascript
JavaScript实现弹出子窗口并传值给父窗口
2014/12/18 Javascript
Underscore.js常用方法总结
2015/02/28 Javascript
推荐10 个很棒的 jQuery 特效代码
2015/10/04 Javascript
JS日期加减,日期运算代码
2015/11/05 Javascript
js判断当前页面在移动设备还是在PC端中打开
2016/01/06 Javascript
Yarn的安装与使用详细介绍
2016/10/25 Javascript
Angular工具方法学习
2016/12/26 Javascript
jquery.cookie.js的介绍与使用方法
2017/02/09 Javascript
解决ztree搜索中多级菜单展示不全问题
2017/07/05 Javascript
js传递数组参数到后台controller的方法
2018/03/29 Javascript
vue自定义移动端touch事件之点击、滑动、长按事件
2018/07/10 Javascript
泛谈JS逻辑判断选择器 || &amp;&amp;
2019/05/24 Javascript
解决vue更新路由router-view复用组件内容不刷新的问题
2019/11/04 Javascript
js实现限定范围拖拽的示例
2020/10/26 Javascript
Python处理文本换行符实例代码
2018/02/03 Python
python设计微型小说网站(基于Django+Bootstrap框架)
2019/07/08 Python
如何利用python之wxpy模块玩转微信
2020/08/17 Python
如何解决python多种版本冲突问题
2020/10/13 Python
使用canvas绘制超炫时钟
2014/12/17 HTML / CSS
联想西班牙官网:Lenovo西班牙
2018/08/28 全球购物
库存图片、照片、矢量图、视频和音乐:Shutterstock
2021/02/12 全球购物
Penhaligon’s英国官网:成立于1870年的英国香水制造商
2021/02/18 全球购物
文秘专业大学生求职信
2013/11/10 职场文书
商场活动策划方案
2014/01/24 职场文书
《槐乡五月》教学反思
2014/04/25 职场文书
母亲节演讲稿
2014/05/27 职场文书
应用心理学专业求职信
2014/08/04 职场文书
教师批评与自我批评发言稿
2014/10/15 职场文书
总经理助理岗位职责范本
2015/03/31 职场文书
2015年网管个人工作总结
2015/05/22 职场文书
联谊会开场白
2015/06/01 职场文书