vue 高德地图之玩转周边

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

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

完整的项目代码请查看  我的github   demo的预览地址 

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

1149975-20170615165945103-1811100363.png

 二 、原理分析

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
      }

三、结果展示

1149975-20170615172033446-1142047806.png

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

转载请注明原文地址 谢谢!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 高德地图周边附近是一个使用 Vue.js 框架来展示高德地图的功能。Vue.js 是一个流行的前端框架,能够帮助开发者构建用户界面。而高德地图则是国内领先的地图服务提供商,提供各种地图相关的功能和数据。 使用 Vue 和高德地图的组合,我们可以通过调用高德地图的 API 来获取地理位置信息,并在网页上显示出来。例如,可以使用高德地图的 JavaScript API 来获取周边地理位置的信息,然后在 Vue 组件中将这些信息展示出来。 在 Vue 组件中,我们可以使用 `mounted` 生命周期钩子函数来在组件加载完毕后调用高德地图的 API。通过调用 API 来获取当前用户所在位置的经纬度,并使用这些信息进行周边搜索。搜索结果可以是餐厅、购物中心等周边设施的信息。 一旦获取到了周边地理位置的信息,我们可以使用 Vue 的数据绑定机制将这些信息渲染到网页上,并展示在视图中。例如,可以使用 Vue 的列表渲染功能将获取到的周边位置逐一展示出来。 同时,我们还可以添加一些交互功能,如点击某个周边位置,可以展示更详细的信息窗口。这可以通过调用高德地图 API 的弹窗功能来实现,并结合 Vue 的事件监听机制来触发弹窗的显示。 总而言之,Vue 高德地图周边附近是一个结合了 Vue.js 框架和高德地图的功能,能够帮助开发者展示周边地理位置信息的网页应用。通过优雅的 Vue 组件和强大的高德地图 API,用户可以方便地浏览并了解周边设施的情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值