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 相关文章推荐
JS随机生成不重复数据的实例方法
Jul 17 Javascript
深入浅出分析javaScript中this用法
May 09 Javascript
JavaScript创建对象的方式小结(4种方式)
Dec 17 Javascript
jQuery内容折叠效果插件用法实例分析(附demo源码)
Apr 28 Javascript
JS简单实现tab切换效果的多窗口显示功能
Sep 07 Javascript
Jquery Easyui分割按钮组件SplitButton使用详解(17)
Dec 18 Javascript
canvas实现流星雨的背景效果
Jan 13 Javascript
JSON对象转化为字符串详解
Aug 11 Javascript
基于Bootstrap表单验证功能
Nov 17 Javascript
jQuery+datatables插件实现ajax加载数据与增删改查功能示例
Apr 17 jQuery
vee-validate vue 2.0自定义表单验证的实例
Aug 28 Javascript
Vue 请求传公共参数的操作
Jul 31 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处理换行符的问题 \r\n
2013/06/13 PHP
php不使用插件导出excel的简单方法
2014/03/04 PHP
php使用glob函数快速查询指定目录文件的方法
2014/11/15 PHP
php生成静态页面并实现预览功能
2019/06/27 PHP
Yii2.0框架模型添加/修改/删除数据操作示例
2019/07/18 PHP
Javascript 个人笔记(没有整理,很乱)
2007/07/07 Javascript
javascript获取xml节点的最大值(实现代码)
2013/12/11 Javascript
jquery序列化方法实例分析
2015/06/10 Javascript
JavaScript给input的value赋值引发的关于基本类型值和引用类型值问题
2015/12/07 Javascript
jQuery基于排序功能实现上移、下移的方法
2016/11/26 Javascript
利用iscroll4实现轮播图效果实例代码
2017/01/11 Javascript
node.js express中app.param的用法详解
2017/07/16 Javascript
JS对象序列化成json数据和json数据转化为JS对象的代码
2017/08/23 Javascript
浅谈 Vue 项目优化的方法
2017/12/16 Javascript
动态内存分配导致影响Javascript性能的问题
2018/12/18 Javascript
关于AngularJS中几种Providers的区别总结
2020/05/17 Javascript
Javascript call及apply应用场景及实例
2020/08/26 Javascript
Vite和Vue CLI的优劣
2021/01/30 Vue.js
[06:04]DOTA2英雄梦之声Vol19卓尔游侠
2014/06/20 DOTA
python实现二维插值的三维显示
2018/12/17 Python
pyqt 实现在Widgets中显示图片和文字的方法
2019/06/13 Python
python模块如何查看
2020/06/16 Python
如何用用Python将地址标记在地图上
2021/02/07 Python
video实现有声音自动播放的实现方法
2020/05/20 HTML / CSS
英国在线电子和小工具商店:TecoBuy
2018/10/06 全球购物
美国购买韩国护肤和美容产品网站:Althea Korea
2020/11/16 全球购物
linux面试题参考答案(3)
2012/09/13 面试题
毕业实习个人鉴定范文
2013/12/10 职场文书
网络专业学生个人的自我评价
2013/12/16 职场文书
如何写好升职自荐信
2014/01/06 职场文书
酒鬼酒广告词
2014/03/21 职场文书
经典的毕业生自荐信范文
2014/04/14 职场文书
建设工程授权委托书
2014/09/22 职场文书
酒店员工辞职信范文
2015/02/28 职场文书
党校团干班培训心得体会
2016/01/06 职场文书
浅谈redis的过期时间设置和过期删除机制
2022/03/18 MySQL