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 相关文章推荐
jquery实现marquee效果(文字或者图片的水平垂直滚动)
Jan 07 Javascript
jquery如何扑捉回车键触发的事件
Apr 24 Javascript
jQuery 过滤方法filter()选择具有特殊属性的元素
Jun 15 Javascript
深入分析Javascript跨域问题
Apr 17 Javascript
javascript实现九宫格相加数值相等
May 28 Javascript
bootstrap+jQuery实现的动态进度条功能示例
May 25 jQuery
node文件上传功能简易实现代码
Jun 16 Javascript
浅谈node中的cluster集群
Jun 02 Javascript
浅谈Angular 观察者模式理解
Nov 01 Javascript
开发中常用的25个JavaScript单行代码(小结)
Jun 28 Javascript
微信公众号服务器验证Token步骤图解
Dec 30 Javascript
vue 页面跳转的实现方式
Jan 12 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
Protoss魔法科技
2020/03/14 星际争霸
用PHP连mysql和oracle数据库性能比较
2006/10/09 PHP
php allow_url_include的应用和解释
2010/04/22 PHP
php多进程模拟并发事务产生的问题小结
2018/12/07 PHP
Laravel6.0.4中将添加计划任务事件的方法步骤
2019/10/15 PHP
用正则获取指定路径文件的名称
2007/02/27 Javascript
js的with语句使用方法
2007/09/21 Javascript
jquery.autocomplete修改实现键盘上下键自动填充示例
2013/11/19 Javascript
jquery获取元素索引值index()示例
2014/02/13 Javascript
JS弹出层单纯的绝对定位居中示例代码
2014/02/18 Javascript
jQuery打印图片pdf、txt示例代码
2014/07/22 Javascript
Vue.js组件tabs实现选项卡切换效果
2016/12/01 Javascript
详解微信小程序开发之——wx.showToast(OBJECT)的使用
2017/01/18 Javascript
JS实现上传图片的三种方法并实现预览图片功能
2017/07/14 Javascript
微信小程序wepy框架笔记小结
2018/08/08 Javascript
Vue面试题及Vue知识点整理
2018/10/07 Javascript
vue elementUI table表格数据 滚动懒加载的实现方法
2019/04/04 Javascript
详解VSCode配置启动Vue项目
2019/05/14 Javascript
vue-cli 3 全局过滤器的实例代码详解
2019/06/03 Javascript
javascript/jquery实现点击触发事件的方法分析
2019/11/11 jQuery
py中的目录与文件判别代码
2008/07/16 Python
微信跳一跳python自动代码解读1.0
2018/01/12 Python
如何在django里上传csv文件并进行入库处理的方法
2019/01/02 Python
Python pyautogui模块实现鼠标键盘自动化方法详解
2020/02/17 Python
联想墨西哥官方网站:Lenovo墨西哥
2016/08/17 全球购物
Mankind西班牙男士护肤品网站:购买皮肤护理、护发和剃须
2017/04/27 全球购物
研究生自我鉴定范文
2013/10/30 职场文书
《雨点》教学反思
2014/02/12 职场文书
销售顾问岗位职责
2014/02/25 职场文书
公司门卫岗位职责
2014/03/15 职场文书
党员创先争优公开承诺书
2014/03/28 职场文书
金融专业银行实习证明模板
2014/11/28 职场文书
2015新年寄语(一句话)
2014/12/08 职场文书
自荐信大全
2019/03/21 职场文书
深入理解python协程
2021/06/15 Python
Python移位密码、仿射变换解密实例代码
2021/06/27 Python