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实现禁止后退的方法
Dec 27 Javascript
jQuery实现的多级下拉菜单效果代码
Aug 24 Javascript
javascript合并表格单元格实例代码
Jan 03 Javascript
JS动态插入并立即执行回调函数的方法
Apr 21 Javascript
bootstrap table小案例
Oct 21 Javascript
JS高级运动实例分析
Dec 20 Javascript
jQuery使用EasyUi实现三级联动下拉框效果
Mar 08 Javascript
详解jQuery同步Ajax带来的UI线程阻塞问题及解决办法
Aug 09 jQuery
详解vue 项目白屏解决方案
Oct 31 Javascript
Vue中axios的封装(报错、鉴权、跳转、拦截、提示)
Aug 20 Javascript
JS异步宏队列与微队列原理区别详解
Jul 02 Javascript
vue 根据选择的月份动态展示日期对应的星期几
Feb 06 Vue.js
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循环输出数据库内容的代码
2008/05/24 PHP
PHP array_multisort()函数的使用札记
2011/07/03 PHP
php中实现用数组妩媚地生成要执行的sql语句
2015/07/10 PHP
smarty高级特性之过滤器的使用方法
2015/12/25 PHP
PHP与jquery实时显示网站在线人数实例详解
2016/12/02 PHP
JavaScript 检测浏览器和操作系统的脚本
2008/12/26 Javascript
flexigrid 类似ext grid的JS表格代码
2010/07/17 Javascript
为开发者准备的10款最好的jQuery日历插件
2014/02/04 Javascript
Javascript字符串对象的常用方法简明版
2014/06/26 Javascript
javascript属性访问表达式用法分析
2015/04/25 Javascript
clipboard.js无需Flash无需依赖任何JS库实现文本复制与剪切
2015/10/10 Javascript
Javascript小技能总结(推荐)
2016/06/02 Javascript
原生js实现tab选项卡切换
2020/03/23 Javascript
详解JS中定时器setInterval和setTImeout的this指向问题
2017/01/06 Javascript
Angular2数据绑定详解
2017/04/18 Javascript
Vue中的数据监听和数据交互案例解析
2017/07/12 Javascript
JS使用setInterval实现的简单计时器功能示例
2018/04/19 Javascript
对vuejs的v-for遍历、v-bind动态改变值、v-if进行判断的实例讲解
2018/08/27 Javascript
python实现将pvr格式转换成pvr.ccz的方法
2015/04/28 Python
python判断windows系统是32位还是64位的方法
2015/05/11 Python
Python实现的概率分布运算操作示例
2017/08/14 Python
python清除字符串前后空格函数的方法
2018/10/21 Python
python Selenium实现付费音乐批量下载的实现方法
2019/01/24 Python
Python如何读写二进制数组数据
2020/08/01 Python
Python获取指定网段正在使用的IP
2020/12/14 Python
html5录音功能实战示例
2019/03/25 HTML / CSS
在DELPHI中调用存储过程和使用内嵌SQL哪种方式更好
2016/11/22 面试题
财务与信息服务专业推荐信
2013/11/28 职场文书
化学实验员岗位职责
2013/12/28 职场文书
办公室人员先进事迹
2014/01/27 职场文书
幼儿教师演讲稿
2014/05/06 职场文书
个人四风问题对照检查材料
2014/09/26 职场文书
2015年高二班主任工作总结
2015/05/25 职场文书
Angular CLI发布路径的配置项浅析
2021/03/29 Javascript
Vue Element-ui表单校验规则实现
2021/07/09 Vue.js
JavaScript 定时器详情
2021/11/11 Javascript