vue高德地图之玩转周边


Posted in Javascript onJune 16, 2017

前言:在之前的博客中,有成功引入高德地图,这是以前的地址  vue 调用高德地图。

因为一些需求,需要使用到地图的周边功能。

完整的项目代码请查看  我的github

一 、先看要实现的结果,参考了链家的周边,如图所示。

vue高德地图之玩转周边

 二 、原理分析

1、引入高德api,这个在之前的博客提到过,vue 调用高德地图。

2、使用地图的周边插件,这是  高德网站的api。

AMap.PlaceSearch //地点搜索服务插件,提供某一特定地区的位置查询服务

在插件中的各种方法中选取了searchNearBy的方法。

searchNearBy(keyword:String,center:LngLat,radius:Number,
callback:function(status:String,result:info/SearchResult))
 
// 根据中心点经纬度、半径以及关键字进行周边查询
radius取值范围:0-50000

3、构建查询方法

searchData: function (callback) {
  let keyWords = ['地铁线路', '大型购物广场', '三甲医院', '学校'] // 自选关键词
  let distance = [1000, 3000, 3000, 3000]
  // …………………………………………………………周边分类…………………………………………………………………………………………………………
  placeSearchOptions = { // 构造地点查询类
  pageSize: 10,
  pageIndex: 1,
  city: '021', // 城市
  map: map,
  visible: false
  }
  AMap.service('AMap.PlaceSearch', function () {
  map.clearMap() // 清除地图覆盖物
  placeSearch = new AMap.PlaceSearch(placeSearchOptions)
  for (let i = 0; i < keyWords.length; i++) {
   placeSearch.searchNearBy(keyWords[i], [121.44343879031237, 31.207570983863118], distance[i], callback)
  }
  })
  return callback
 },

在这个方法中,将所有的maker都查找出来,为了能够让后续不重新加载地图和插件,如有更好的方法 ,欢迎指出。

4、将maker的切换事件绑定在footer下的各个选项中。

/* 注册每项的点击事件,默认显示num0,也就是交通,实际上所有的数据已经请求到了,点击按钮只是用来切换maker */
  clickItem: function (index, buttons) {
  map.clearMap() // 清除地图覆盖物
  buttons.forEach(function (e, index) {
   e.isActive = false
  })
  buttons[index].isActive = true
  self.listCount = self.num[index].length
  self.listText = self.num[index]
  function onClick (e) {
   console.log(e)
  }
  for (let i = 0; i < self.num[index].length; i++) {
   marker = new AMap.Marker({
//   content: 'div',
   title: 'abc',
   icon: 'https://webapi.amap.com/theme/v1.3/markers/n/mark_b' + (i + 1) + '.png',
   position: [self.num[index][i].location.lng, self.num[index][i].location.lat],
   offset: new AMap.Pixel(-24, 5),
   zIndex: 1,
   map: map,
   clickable: true
   })
   AMap.event.addListener(marker, 'click', onClick)
  }
  return marker
  }

三、结果展示

vue高德地图之玩转周边

注意:为方便演示效果,此项目中使用了个人开发者的高德秘钥,请自行去替换成自己的。

完整的项目代码请查看  我的github

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Using the TextRange Object
Oct 14 Javascript
JS批量操作CSS属性详细解析
Dec 16 Javascript
Angular 页面跳转时传参问题
Aug 01 Javascript
javascript十六进制数字和ASCII字符之间的转换方法
Dec 27 Javascript
jQuery实现鼠标响应式透明度渐变动画效果示例
Feb 13 jQuery
详解从Vue-router到html5的pushState
Jul 21 Javascript
浅谈Vue数据响应思路之数组
Nov 06 Javascript
Vue插件从封装到发布的完整步骤记录
Feb 28 Javascript
原生js实现二级联动菜单
Nov 27 Javascript
在Vue中使用Viser说明(基于AntV-G2可视化引擎)
Oct 28 Javascript
JavaScript 中的六种循环方法
Jan 06 Javascript
VUE之图片Base64编码使用ElementUI组件上传
Apr 09 Vue.js
JavaScript实现提交模式窗口后刷新父窗口数据的方法
Jun 16 #Javascript
JS 组件系列之BootstrapTable的treegrid功能
Jun 16 #Javascript
vue之数据交互实例代码
Jun 16 #Javascript
基于jQuery和CSS3实现APPLE TV海报视差效果
Jun 16 #jQuery
JS基于正则实现数字千分位用逗号分隔的方法
Jun 16 #Javascript
利用jquery去掉时光轴头尾部线条的方法实例
Jun 16 #jQuery
基于JS实现网页中的选项卡(两种方法)
Jun 16 #Javascript
You might like
全国FM电台频率大全 - 15 山东省
2020/03/11 无线电
php算开始时间到过期时间的相隔的天数
2011/01/12 PHP
destoon出现验证码不显示时的紧急处理方法
2014/08/22 PHP
PHP5多态性与动态绑定介绍
2015/04/03 PHP
简单谈谈php中的unicode和utf8编码
2015/06/10 PHP
通用javascript脚本函数库 方便开发
2009/10/13 Javascript
checkbox全选所涉及到的知识点介绍
2013/12/31 Javascript
七个很有意思的PHP函数
2014/05/12 Javascript
AngularJS 遇到的小坑与技巧小结
2016/06/07 Javascript
遍历js中对象的属性和值的实例
2016/11/21 Javascript
微信小程序实现顶部普通选项卡效果(非swiper)
2020/06/19 Javascript
关于JavaScript语句后面的分号问题
2017/12/07 Javascript
浅谈VUE监听窗口变化事件的问题
2018/02/24 Javascript
JS实现判断图片是否加载完成的方法分析
2018/07/31 Javascript
详解vue如何使用rules对表单字段进行校验
2018/10/17 Javascript
Python和php通信乱码问题解决方法
2014/04/15 Python
python教程之用py2exe将PY文件转成EXE文件
2014/06/12 Python
python实现的重启关机程序实例
2014/08/21 Python
详解使用Python处理文件目录的相关方法
2015/10/16 Python
Python编译为二进制so可执行文件实例
2019/12/23 Python
详解css3 object-fit属性
2018/07/27 HTML / CSS
详解CSS3中nth-child与nth-of-type的区别
2017/01/05 HTML / CSS
HTML5中input[type='date']自定义样式与日历校验功能的实现代码
2017/07/11 HTML / CSS
中专毕业生自我鉴定
2013/11/21 职场文书
护理实习自我鉴定
2013/12/14 职场文书
军训鉴定表自我鉴定
2014/02/13 职场文书
餐饮总经理岗位职责
2014/03/07 职场文书
教师见习报告范文
2014/11/03 职场文书
新婚姻法离婚协议书范文
2014/11/30 职场文书
2015年客房服务员工作总结
2015/05/15 职场文书
调解书格式范本
2015/05/20 职场文书
超强台风观后感
2015/06/09 职场文书
小学科学课教学反思
2016/02/23 职场文书
2019行政前台转正申请书范文3篇
2019/08/15 职场文书
浅谈spring boot使用thymeleaf版本的问题
2021/08/04 Java/Android
分享CSS盒子模型隐藏的几种方式
2022/02/28 HTML / CSS