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 方法实现返回多个数据的代码
Apr 30 Javascript
一个页面元素appendchild追加到另一个页面元素的问题
Jan 27 Javascript
js实现屏蔽默认快捷键调用自定义事件示例
Jun 18 Javascript
javascript 3d 逐侦产品展示(核心精简)
Mar 26 Javascript
IE浏览器不支持getElementsByClassName的解决方法
Aug 27 Javascript
JavaScript中的定时器之Item23的合理使用
Oct 30 Javascript
javascript实现无缝上下滚动特效
Dec 16 Javascript
Javascript基于对象三大特性(封装性、继承性、多态性)
Jan 04 Javascript
jQuery实现立体式数字动态增加(animate方法)
Dec 21 Javascript
用node-webkit把web应用打包成桌面应用(windows环境)
Feb 01 Javascript
在vue中v-bind使用三目运算符绑定class的实例
Sep 29 Javascript
js实现延迟加载的几种方法详解
Jan 19 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
咖啡与水的关系
2021/03/03 冲泡冲煮
浅析php学习的路线图
2013/07/10 PHP
javascript引用对象的方法代码
2007/08/13 Javascript
javascript 操作select下拉列表框的一点小经验
2010/03/20 Javascript
Javascript级联下拉菜单以及AJAX数据验证核心代码
2013/05/10 Javascript
用javascript判断IE版本号简单实用且向后兼容
2013/09/11 Javascript
微信 java 实现js-sdk 图片上传下载完整流程
2016/10/21 Javascript
怎样判断jQuery当前元素是隐藏还是显示
2016/11/23 Javascript
解析JavaScript模仿块级作用域
2016/12/29 Javascript
css和js实现弹出登录居中界面完整代码
2017/11/26 Javascript
vue2.0 自定义 饼状图 (Echarts)组件的方法
2018/03/02 Javascript
vue用递归组件写树形控件的实例代码
2018/07/19 Javascript
对Layer UI 模块化的用法详解
2019/09/26 Javascript
python中私有函数调用方法解密
2016/04/29 Python
django之session与分页(实例讲解)
2017/11/13 Python
PyCharm代码格式调整方法
2018/05/23 Python
解决python中 f.write写入中文出错的问题
2018/10/31 Python
Python中的异常处理try/except/finally/raise用法分析
2019/02/28 Python
python命令行参数用法实例分析
2019/06/25 Python
python实现的登录与提交表单数据功能示例
2019/09/25 Python
Django中密码的加密、验密、解密操作
2019/12/19 Python
python 读取更新中的log 或其它文本方式
2019/12/24 Python
windows10环境下用anaconda和VScode配置的图文教程
2020/03/30 Python
浅析Python 简单工厂模式和工厂方法模式的优缺点
2020/07/13 Python
python中子类与父类的关系基础知识点
2021/02/02 Python
世界首屈一指的在线男士内衣权威:HisRoom
2017/08/05 全球购物
美国修容界大佬创建的个人美妆品牌:Kevyn Aucoin Beauty
2018/12/12 全球购物
Craghoppers德国官网:户外和旅行服装
2020/02/14 全球购物
增员口号大全
2014/06/18 职场文书
演讲比赛的活动方案
2014/08/28 职场文书
活动总结格式
2014/08/30 职场文书
2014小学一年级班主任工作总结
2014/12/05 职场文书
党员检讨书范文
2014/12/27 职场文书
2016年小学生清明节广播稿
2015/12/17 职场文书
2016年“9.22”世界无车日活动小结
2016/04/05 职场文书
教你用Java在个人电脑上实现微信扫码支付
2021/06/13 Java/Android