vue-cli中使用高德地图的方法示例

作者:树沙& 时间:2024-04-27 16:09:39 

第一步 去高德地图开放平台申请密钥  高德地图开放平台

vue-cli中使用高德地图的方法示例

第二部 在vue-cli项目目录结构 

vue-cli中使用高德地图的方法示例

里面多了config文件夹和 utils文件夹 

config.js里面是这样的  主要是导出密钥 


// 高德地图 key
export const MapKey = '你的密钥key'
// 地图限定城市
export const MapCityName = '武汉'

utils文件夹里面 新建路一个remoteLoad.js

主要是动态创建script标签 封装了一个函数 传入URL地址()


export default function remoteLoad (url, hasCallback) {
return createScript(url)
/**
 * 创建script
 * @param url
 * @returns {Promise}
 */
function createScript (url) {
 var scriptElement = document.createElement('script')
 document.body.appendChild(scriptElement)
 var promise = new Promise((resolve, reject) => {
  scriptElement.addEventListener('load', e => {
   removeScript(scriptElement)
   if (!hasCallback) {
    resolve(e)
   }
  }, false)

scriptElement.addEventListener('error', e => {
   removeScript(scriptElement)
   reject(e)
  }, false)

if (hasCallback) {
   window.____callback____ = function () {
    resolve()
    window.____callback____ = null
   }
  }
 })

if (hasCallback) {
  url += '&callback=____callback____'
 }

scriptElement.src = url

return promise
}

/**
 * 移除script标签
 * @param scriptElement script dom
 */
function removeScript (scriptElement) {
 document.body.removeChild(scriptElement)
}
}

第三步 在Home组件中


<template>
<div class="m-map">
 <div class="search" v-if="placeSearch">
  <input type="text" placeholder="请输入关键字" v-model="searchKey">
  <button type="button" @click="handleSearch">搜索</button>
  <div id="js-result" v-show="searchKey" class="result"></div>
 </div>
 <div id="js-container" class="map"></div>
</div>
</template>

<script>
import remoteLoad from '@/utils/remoteLoad.js'
import { MapKey, MapCityName } from '@/config/config'
export default {
props: ['lat', 'lng'],
data () {
 return {
  searchKey: '',
  placeSearch: null,
  dragStatus: false,
  AMapUI: null,
  AMap: null
 }
},
watch: {
 searchKey () {
  if (this.searchKey === '') {
   this.placeSearch.clear()
  }
 }
},
methods: {
 // 搜索
 handleSearch () {
  if (this.searchKey) {
   this.placeSearch.search(this.searchKey)
  }
 },
 // 实例化地图
 initMap () {
  // 加载PositionPicker,loadUI的路径参数为模块名中 'ui/' 之后的部分
  let AMapUI = this.AMapUI = window.AMapUI
  let AMap = this.AMap = window.AMap
  AMapUI.loadUI(['misc/PositionPicker'], PositionPicker => {
   let mapConfig = {
    zoom: 16,
    cityName: MapCityName
   }
   if (this.lat && this.lng) {
    mapConfig.center = [this.lng, this.lat]
   }
   let map = new AMap.Map('js-container', mapConfig)
   // 加载地图搜索插件
   AMap.service('AMap.PlaceSearch', () => {
    this.placeSearch = new AMap.PlaceSearch({
     pageSize: 5,
     pageIndex: 1,
     citylimit: true,
     city: MapCityName,
     map: map,
     panel: 'js-result'
    })
   })
   // 启用工具条
   AMap.plugin(['AMap.ToolBar'], function () {
    map.addControl(new AMap.ToolBar({
     position: 'RB'
    }))
   })
   // 创建地图拖拽
   let positionPicker = new PositionPicker({
    mode: 'dragMap', // 设定为拖拽地图模式,可选'dragMap'、'dragMarker',默认为'dragMap'
    map: map // 依赖地图对象
   })
   // 拖拽完成发送自定义 drag 事件
   positionPicker.on('success', positionResult => {
    // 过滤掉初始化地图后的第一次默认拖放
    if (!this.dragStatus) {
     this.dragStatus = true
    } else {
     this.$emit('drag', positionResult)
    }
   })
   // 启动拖放
   positionPicker.start()
  })
 }
},
async created () {
 // 已载入高德地图API,则直接初始化地图
 if (window.AMap && window.AMapUI) {
  this.initMap()
 // 未载入高德地图API,则先载入API再初始化
 } else {
  await remoteLoad(`http://webapi.amap.com/maps?v=1.3&key=${MapKey}`)
  await remoteLoad('http://webapi.amap.com/ui/1.0/main.js')
  this.initMap()
 }
}
}
</script>

<style lang="css">
.m-map{ min-width: 500px; min-height: 300px; position: relative; }
.m-map .map{ width: 100%; height: 100%; }
.m-map .search{ position: absolute; top: 10px; left: 10px; width: 285px; z-index: 1; }
.m-map .search input{ width: 180px; border: 1px solid #ccc; line-height: 20px; padding: 5px; outline: none; }
.m-map .search button{ line-height: 26px; background: #fff; border: 1px solid #ccc; width: 50px; text-align: center; }
.m-map .result{ max-height: 300px; overflow: auto; margin-top: 10px; }
</style>

第四步  在app.vue中 导入组件


<template>
<div id="app">
 <div class="g-wraper">
  <div class="m-part">
   <mapDrag @drag="dragMap" class="mapbox"></mapDrag>
  </div>
 </div>

</div>
</template>

<script>
import mapDrag from './components/Home.vue'
export default {
name: 'app',
components: {
 mapDrag
},
data () {
 return {
  dragData: {
   lng: null,
   lat: null,
   address: null,
   nearestJunction: null,
   nearestRoad: null,
   nearestPOI: null
  }
 }
},
methods: {
 dragMap (data) {
  console.log(data)
  this.dragData = {
   lng: data.position.lng,
   lat: data.position.lat,
   address: data.address,
   nearestJunction: data.nearestJunction,
   nearestRoad: data.nearestRoad,
   nearestPOI: data.nearestPOI
  }
 }
}
}
</script>

<style>
body{ margin: 0; }
.page-header{
color: #fff; text-align: center; background: #159957;
background-image: -webkit-linear-gradient(330deg,#155799,#159957);
background-image: linear-gradient(120deg,#155799,#159957);
padding: 3rem 4rem; margin-bottom: 30px;
}
.page-header h1{ margin: 0; font-size: 40px; }
.page-header p{ color: #ccc; margin: 0; margin-bottom: 30px; }
.page-header a{ display: inline-block; border: 1px solid #fff; margin-right: 10px; line-height: 40px; padding: 0 20px; border-radius: 4px; color: #fff; text-decoration: none; transition: all .3s; }
.page-header a:hover{ background: #fff; color: #333; }
.g-wraper{ width: 1000px; margin: 0 auto; color: #666; font-size: 16px; line-height: 30px; }
.m-part{ margin-bottom: 30px; }
.m-part::after{ content: ''; display: block; clear: both; }
.m-part .title{ font-size: 30px; line-height: 60px; margin-bottom: 10px; color: #333; }
.m-part .mapbox{ width: 600px; height: 400px; margin-bottom: 20px; float: left; }
.m-part .info{ margin: 0; padding: 0; list-style: none; line-height: 30px; margin-left: 620px; }
.m-part .info span{ display: block; color: #999; }
.m-part ol{ line-height: 40px; margin-left: 0; padding-left: 0; }
.m-part pre{ padding: 10px 20px; line-height: 30px; border-radius: 3px; box-shadow: 0 0 15px rgba(0,0,0,.5); }
.m-footer{ background: #eee; line-height: 60px; text-align: center; color: #999; font-size: 12px; }
.m-footer a{ margin: 0 5px; color: #999; text-decoration: none; }
</style>

上面 地图初始化渲染的方法 直接拿别人封装好的东西

最后运行后

vue-cli中使用高德地图的方法示例

来源:https://blog.csdn.net/hailangtuteng/article/details/80537427

标签:vue-cli,高德地图
0
投稿

猜你喜欢

  • Golang学习笔记(一):简介

    2024-02-22 18:59:28
  • 一文讲解如何查看python脚本所依赖三方包及其版本

    2022-09-17 22:51:04
  • vue中的mescroll搜索运用及各种填坑处理

    2024-04-30 10:26:39
  • JS在IE和FireFox之间常用函数的区别小结

    2024-04-16 09:54:54
  • django queryset相加和筛选教程

    2022-09-10 11:04:43
  • scrapy实践之翻页爬取的实现

    2023-09-25 23:09:26
  • python 中的9个实用技巧,助你提高开发效率

    2021-05-01 08:26:25
  • JavaScript继承模式粗探

    2024-04-23 09:25:20
  • Python request post上传文件常见要点

    2022-11-05 09:27:14
  • 详细讲解MySQL数据库对文件操作的封装

    2008-12-17 16:08:00
  • pygame实现键盘的连续监控

    2023-09-26 11:17:10
  • 详解Spring Security怎么从数据库加载我们的用户

    2024-01-21 18:35:37
  • golang定时器Timer的用法和实现原理解析

    2024-02-17 04:23:08
  • Go语言导出内容到Excel的方法

    2024-02-11 17:18:56
  • Python实现屏幕代码雨效果的示例代码

    2021-08-29 12:48:09
  • Python 分发包中添加额外文件的方法

    2023-02-15 08:43:11
  • Python发送手机动态验证码代码实例

    2021-10-18 23:42:32
  • 在 Python 中使用 7zip 备份文件的操作

    2022-10-01 10:05:56
  • 全面分析Python的优点和缺点

    2023-11-09 11:00:07
  • python版学生管理系统

    2023-07-27 07:21:46
  • asp之家 网络编程 m.aspxhome.com