vue-baidu-map 进入页面自动定位的解决方案(推荐)


Posted in Javascript onApril 28, 2018

写在前面:我只是一个前端小白,文章中的提到可能会有不足之处,仅提供一个参考。若有不完善的地方,欢迎各位大佬指出!,希望对你有帮助!

好了,入正题。其实之前也被这问题困扰过,在网上也查了一番,没找到解决方法。直到今天,在GitHub 冒昧地向大佬提了一个 issue,才点醒了我。其实是因为太过急功近利了,没有认真阅读 vue-baidu-map 提供参考文档,也有可能是看过然后忘记了!

首先要明确一点(文档原话):由于百度地图 JS API 只有 JSONP 一种加载方式,因此 BaiduMap 组件及其所有子组件的渲染只能是异步的。因此,请使用在组件的 ready 事件来执行地图 API 加载完毕后才能执行的代码,不要试图在 vue 自身的生命周期中调用 BMap 类,更不要在这些时机修改 model 层。

错误用法

 我试过,以上这种方法好像是可行,效果可以出来,但我们最好采用作者提供的正确方法!

正确用法

 推荐这种方法!那下面解决进入页面自动定位的方法也是在这里。

 下面是我的写法,仅供参考,有不足请指出,我只是一个小白,哈哈!

Template:

<template>
  <baidu-map class="map" :center="center" :zoom="zoom" @ready="handler" @load="loadding" :scroll-wheel-zoom="true"
    :mapStyle="{styleJson: styleJson}">
    <bm-geolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT" :showAddressBar="false" :autoLocation="true"
      :locationIcon="{url: require('../../svg/location.svg'), size: {width: 18, height: 18}}" 
      @locationSuccess="getLoctionSuccess" @locationError="getLocationError">
    </bm-geolocation>
    <!-- 自定义定位图标覆盖物 -->
    <bm-marker :position="autoLocationPoint"
      :icon="{url: require('../../svg/location.svg'), size: {width: 18, height: 18}}" v-if="initLocation">
    </bm-marker>
  </baidu-map>
</template>

JS实现:

<script>
  export default {
    data () {
      return {
        // 省略一部分
        autoLocationPoint: {lng: 0, lat: 0},
        initLocation: false,
      }
    },
    methods: {
      handler ({BMap, map}) {
        let _this = this;  // 设置一个临时变量指向vue实例,因为在百度地图回调里使用this,指向的不是vue实例;
        var geolocation = new BMap.Geolocation();
        geolocation.getCurrentPosition(function(r){
          console.log(r);
          _this.center = {lng: r.longitude, lat: r.latitude};   // 设置center属性值
          _this.autoLocationPoint = {lng: r.longitude, lat: r.latitude};   // 自定义覆盖物
          _this.initLocation = true; 
          console.log('center:', _this.center)  // 如果这里直接使用this是不行的
        },{enableHighAccuracy: true})

        // 下面注释是百度地图API官方实现方法,因为我使用自定义图标覆盖物,所以没有使用这种方法!
        // 如使用以下这种方法,那么我Template里所写的自定义定位图标代码是不需要的
        // var geolocation = new BMap.Geolocation();
        // geolocation.getCurrentPosition(function(r){
        // if(this.getStatus() == BMAP_STATUS_SUCCESS){
        //   var mk = new BMap.Marker(r.point);
        //   map.addOverlay(mk);
        //   map.panTo(r.point);
        //   alert('您的位置:'+r.point.lng+','+r.point.lat);
        // }
        // else {
        //   alert('failed'+this.getStatus());
        // }
        // },{enableHighAccuracy: true})
      }
    }
  }
</script>

如果是直接复制代码的朋友请注意,要有选择的复制,因为我没有把全部代码贴出了,直接复制到你的项目是会出问题的!不过这代码比较简单,稍微就能看懂,哈哈!

以上所述是小编给大家介绍的vue-baidu-map 进入页面自动定位的解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript 高级篇之DOM文档,简单封装及调用、动态添加、删除样式(六)
Apr 07 Javascript
基于jquery实现的定时显示与隐藏div广告的实现代码
Aug 22 Javascript
jQuery聚合函数实例
May 21 Javascript
使用Angular.js开发的注意事项
Oct 19 Javascript
vue配置请求本地json数据的方法
Apr 11 Javascript
vue.js使用3DES加密的方法示例
May 18 Javascript
Vue 全局loading组件实例详解
May 29 Javascript
微信小程序实现下拉菜单切换效果
Mar 30 Javascript
微信小程序实现滑动切换自定义页码的方法分析
Dec 29 Javascript
Vue快速实现通用表单验证的示例代码
Jan 09 Javascript
微信小程序 wx.getUserInfo引导用户授权问题实例分析
Mar 09 Javascript
通过高德地图API获得某条道路上的所有坐标用于描绘道路的方法
Aug 24 Javascript
Vue2.0实现调用摄像头进行拍照功能 exif.js实现图片上传功能
Apr 28 #Javascript
React native ListView 增加顶部下拉刷新和底下点击刷新示例
Apr 27 #Javascript
React Native日期时间选择组件的示例代码
Apr 27 #Javascript
vue实现点击展开点击收起效果
Apr 27 #Javascript
vue中post请求以a=a&amp;b=b 的格式写遇到的问题
Apr 27 #Javascript
vue项目中应用ueditor自定义上传按钮功能
Apr 27 #Javascript
Vue 使用 Mint UI 实现左滑删除效果CellSwipe
Apr 27 #Javascript
You might like
PHP编程实现csv文件导入mysql数据库的方法
2017/04/29 PHP
用js实现的检测浏览器和系统的函数
2009/04/09 Javascript
Mootools 1.2教程 同时进行多个形变动画
2009/09/15 Javascript
查询绑定数据岛的表格中的文本并修改显示方式的js代码
2009/12/15 Javascript
Javascript代码在页面加载时的执行顺序介绍
2013/05/03 Javascript
jQuery实用函数用法总结
2014/08/29 Javascript
学习Bootstrap组件之下拉菜单
2015/07/28 Javascript
jquery实现简单Tab切换菜单效果
2020/07/17 Javascript
JavaScript制作简易计算器(不用eval)
2017/02/05 Javascript
JavaScript实现的数字与字符串转换功能示例
2017/08/23 Javascript
Async/Await替代Promise的6个理由
2019/06/15 Javascript
vue-video-player 解决微信自动全屏播放问题(横竖屏导致样式错乱问题)
2020/02/25 Javascript
请不要重复犯我在学习Python和Linux系统上的错误
2016/12/12 Python
Python3简单实例计算同花的概率代码
2017/12/06 Python
Python简单实现网页内容抓取功能示例
2018/06/07 Python
Python3 Post登录并且保存cookie登录其他页面的方法
2018/12/28 Python
如何在django里上传csv文件并进行入库处理的方法
2019/01/02 Python
12个Python程序员面试必备问题与答案(小结)
2019/06/24 Python
pygame实现飞机大战
2020/03/11 Python
利用python中的matplotlib打印混淆矩阵实例
2020/06/16 Python
非常漂亮的CSS3百叶窗焦点图动画
2016/02/24 HTML / CSS
中药专业大学生医药工作求职信
2013/10/25 职场文书
高级技校毕业生自荐信
2013/11/18 职场文书
经典导游欢迎词大全
2014/01/16 职场文书
关于廉洁的广播稿
2014/01/30 职场文书
卫生安全检查制度
2014/02/04 职场文书
优秀护士获奖感言
2014/02/20 职场文书
应届生求职信
2014/05/31 职场文书
学前教育专业求职信
2014/09/02 职场文书
领导干部遵守党的政治纪律情况思想汇报
2014/09/14 职场文书
监察局领导班子四风问题整改措施思想汇报
2014/10/05 职场文书
迎新年主持词
2015/07/06 职场文书
婚礼男方父母答谢词
2015/09/29 职场文书
SQL 窗口函数实现高效分页查询的案例分析
2021/05/21 SQL Server
Spring Boot 排除某个类加载注入IOC的操作
2021/08/02 Java/Android
python turtle绘图命令及案例
2021/11/23 Python