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 相关文章推荐
使用HTML5和CSS3表单验证功能
May 05 HTML / CSS
深入CSS3 动画效果的总结详解
May 09 HTML / CSS
CSS3实例分享--超炫checkbox复选框和radio单选框
Sep 01 HTML / CSS
浅析CSS3 用text-overflow解决文字排版问题
Oct 28 HTML / CSS
HTML5中使用postMessage实现Ajax跨域请求的方法
Apr 19 HTML / CSS
html5拖曳操作 HTML5实现网页元素的拖放操作
Jan 02 HTML / CSS
html5中为audio标签增加停止按钮动作实现方法
Jan 04 HTML / CSS
HTML5 DeviceOrientation实现手机网站摇一摇功能代码实例
Apr 24 HTML / CSS
使用HTML5的Canvas绘制曲线的简单方法
Sep 08 HTML / CSS
html5启动原生APP总结
Jul 03 HTML / CSS
html5使用window.postMessage进行跨域实现数据交互的一次实战
Feb 24 HTML / CSS
html+css实现赛博朋克风格按钮
May 26 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
一个从别的网站抓取信息的例子(域名查询)
2006/10/09 PHP
PHP 自定义错误处理函数的使用详解
2013/05/10 PHP
Laravel中Trait的用法实例详解
2016/03/16 PHP
浅析Laravel5中队列的配置及使用
2016/08/04 PHP
Laravel学习教程之IOC容器的介绍与用例
2017/08/15 PHP
PHP实现websocket通信的方法示例
2018/08/28 PHP
PHP XML Expat解析器知识点总结
2019/02/15 PHP
为指定元素增加样式的js代码
2009/12/09 Javascript
AJAX使用了UpdatePanel后无法使用alert弹出脚本
2010/04/02 Javascript
js中判断数字\字母\中文的正则表达式 (实例)
2012/06/29 Javascript
html+css+js实现xp window界面及有关功能
2013/03/26 Javascript
js螺旋动画效果的具体实例
2013/11/15 Javascript
ajax读取数据后使用jqchart显示图表的方法
2015/06/10 Javascript
jQuery实现的进度条效果
2015/07/15 Javascript
AngularJS  ng-table插件设置排序
2016/09/21 Javascript
Bootstrap table使用方法记录
2017/08/23 Javascript
JS跳转手机站url的若干注意事项
2017/10/18 Javascript
vue2.0 移动端实现下拉刷新和上拉加载更多的示例
2018/04/23 Javascript
JS内置对象和Math对象知识点详解
2020/04/03 Javascript
详解Vue中的MVVM原理和实现方法
2020/07/15 Javascript
[51:06]2018DOTA2亚洲邀请赛3月29日 小组赛A组 KG VS Liquid
2018/03/30 DOTA
[01:12:44]VG vs Mineski Supermajor 败者组 BO3 第二场 6.6
2018/06/07 DOTA
python 实现归并排序算法
2012/06/05 Python
pandas通过loc生成新的列方法
2018/11/28 Python
python 通过类中一个方法获取另一个方法变量的实例
2019/01/22 Python
Python面向对象程序设计之私有属性及私有方法示例
2019/04/08 Python
Python解决pip install时出现的Could not fetch URL问题
2019/08/01 Python
Python实现新型冠状病毒传播模型及预测代码实例
2020/02/05 Python
Vs Code中8个好用的python 扩展插件
2020/10/12 Python
Sneaker Studio乌克兰:购买运动鞋
2018/03/26 全球购物
2015年度合同管理工作总结
2015/05/22 职场文书
2019年教师节活动策划方案
2019/09/09 职场文书
python使用XPath解析数据爬取起点小说网数据
2021/04/22 Python
goland 恢复已更改文件的操作
2021/04/28 Golang
MySQL提取JSON字段数据实现查询
2022/04/22 MySQL
css让页脚保持在底部位置的四种方案
2022/07/23 HTML / CSS