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样式linear-gradient的使用实例
Jan 16 HTML / CSS
CSS3不透明度实例讲解
Apr 26 HTML / CSS
CSS3中的常用选择器使用示例整理
Jun 13 HTML / CSS
CSS3 box-sizing属性详解
Nov 15 HTML / CSS
详解CSS透明opacity和IE各版本透明度滤镜filter的最准确用法
Dec 20 HTML / CSS
HTML5离线缓存Manifest是什么
Mar 09 HTML / CSS
为你的html5网页添加音效示例
Apr 03 HTML / CSS
HTML5在线预览PDF的示例代码
Sep 14 HTML / CSS
html5小程序飞入购物车(抛物线绘制运动轨迹点)
Oct 19 HTML / CSS
HTML5 canvas实现的静态循环滚动播放弹幕
Jan 05 HTML / CSS
CSS变量实现主题切换的方法
Jun 23 HTML / CSS
postman中form-data、x-www-form-urlencoded、raw、binary的区别介绍
Jan 18 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验证邮箱和ip地址最简单方法汇总
2015/10/30 PHP
Zend Framework使用Zend_Loader组件动态加载文件和类用法详解
2016/12/09 PHP
javascript 函数调用的对象和方法
2010/07/01 Javascript
分享一个我自己写的ToolTip提示插件(附源码)
2013/01/20 Javascript
Javascript拓展String方法小结
2013/07/08 Javascript
前端开发过程中浏览器版本的两种判定方法
2013/10/30 Javascript
JavaScript实现鼠标点击后层展开效果的方法
2015/05/13 Javascript
删除javascript所创建子节点的方法
2015/05/21 Javascript
JavaScript中的Math.E属性使用详解
2015/06/12 Javascript
BootStrap CSS全局样式和表格样式源码解析
2017/01/20 Javascript
JS闭包用法实例分析
2017/03/27 Javascript
实例详解JavaScript中setTimeout函数的执行顺序
2017/07/12 Javascript
解决Angular.js中使用Swiper插件不能滑动的问题
2018/02/26 Javascript
在Vue组件中获取全局的点击事件方法
2018/09/06 Javascript
nodejs高大上的部署方式(PM2)
2018/09/11 NodeJs
Angular父子组件通过服务传参的示例方法
2018/10/31 Javascript
javascript中的event loop事件循环详解
2018/12/14 Javascript
[01:02:17]2014 DOTA2华西杯精英邀请赛 5 24 DK VS VG
2014/05/26 DOTA
[00:26]TI7不朽珍藏III——冥界亚龙不朽展示
2017/07/15 DOTA
Python中使用PyHook监听鼠标和键盘事件实例
2014/07/18 Python
跟老齐学Python之做一个小游戏
2014/09/28 Python
详解Python3中yield生成器的用法
2015/08/20 Python
Django 内置权限扩展案例详解
2019/03/04 Python
python3发送邮件需要经过代理服务器的示例代码
2019/07/25 Python
Python3分析处理声音数据的例子
2019/08/27 Python
python urllib爬虫模块使用解析
2019/09/05 Python
python模块hashlib(加密服务)知识点讲解
2019/11/25 Python
Canal官网:巴西女性时尚品牌
2019/10/16 全球购物
多媒体编辑专业毕业生推荐信
2013/11/05 职场文书
中层干部竞争上岗演讲稿
2014/01/13 职场文书
2015年元旦活动总结
2014/05/09 职场文书
高中课前三分钟演讲稿
2014/09/13 职场文书
三年级学生期末评语
2014/12/26 职场文书
培训心得体会怎么写
2016/01/25 职场文书
小学科学课教学反思
2016/02/23 职场文书
Nginx URL重写rewrite机制原理及使用实例
2021/04/01 Servers