1. 程式人生 > 程式設計 >前端vue如何使用高德地圖

前端vue如何使用高德地圖

首先,註冊Key

 1、註冊開發者賬號,成為高德開放平臺開發者

2、登陸之後,在進入「應用管理」 頁面「建立新應用」

 3、為應用新增 Key,「服務平臺」一項請選擇「 Web 端 ( JSAPI ) 」

然後,書寫程式碼

在vuecli public資料夾中的index.html新增匯入JS API 的入口指令碼標籤

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width,initial-scale=1.0">
  <link rel="icon" href="./iconLink.png" rel="external nofollow" >
  <title>高德地圖</title>
    <!-- 建議將匯入的script寫在body前面,以便提前載入 -->
  <script type="text/javascript" src="http://webapi.amap.com/maps?v=2.0&key=d6c35bb2619f107f86ccda4b378415f6&plugin=AMap.MouseTool"></script> <!-- 只是我的key,可以暫時用為測試(不定什麼時候失效) -->
   <script src="//webapi.amap.com/ui/1.1/main.js?v=1.1.1"></script> <!-- 高德官方文件的ui庫 --> </head> <body> <div id="app"></div> </body>
</html>

在vue.config.js中修改配置

module.exports = {
  publicPath: "./",configureWebpack: {
    externals: {
      AMap: 'window.AMap',AMapUI: 'window.AMapUI' // 高德地圖配置
    },}
};

接下來,正式書寫vue元件

廢話不多說,直接上程式碼

<template>
  <div class="map_wrapper">
    <div class="box">
      <div id="container" style="width: 100%; height: 500px"></div>
    </div>
  </div>
</template>

<script lang="ts">
import { Vue,Component,Prop,Watch } from 'vue-property-decorator';
@Component({
})
export default class page extends Vue {   // 使用 import AMap from 'amap'; 會有編輯器報錯Cannot find module 'amap'; 所以變通換一種寫法
  protected AMap: any = (window as any).AMap;
  protected AMapUI: any = (window as any).AMapUI;
   // 如果寫在created會報錯 "Error: Map container div not exist"
  mounted() {
      let map = new this.AMap.Map('container',{
        center: [121.227577,31.101471],// 中心點座標
        resizeEnable: true,// 是否監控地圖容器尺寸變化
        zoom: 10,// 初始化地圖層級,可以理解為縮放比例
        showMarker: true,// 定位成功後在定位到的位置顯示點標記,預設:true
      });

      //載入SimpleInfoWindow,loadUI的路徑引數為模組名中 'ui/' 之後的部分
      this.AMapUI.loadUI(['overlay/SimpleInfoWindow'],(SimpleInfoWindow: any) => {
        let marker = new this.AMap.Marker({
          map: map,zIndex: 9999999,position: map.getCenter(),});

        let infoWindow = new SimpleInfoWindow({
          infoTitle: '<strong>這裡是標題</strong>',infoBody: '<p>這裡是內容。</p>',offset: new this.AMap.Pixel(0,-31),// 文字定位偏移
        });
        //顯示在map上
        function openInfoWin() {
          infoWindow.open(map,marker.getPosition());
        }
        marker.on('click',() => {
          openInfoWin(); // 點選標記時顯示文字
        });
        openInfoWin();
      });
  }
}
</script>

<style scoped lang="scss"></style>

頁面效果如下

前端vue如何使用高德地圖

以上就是前端vue如何使用高德地圖的詳細內容,更多關於vue 高德地圖的資料請關注我們其它相關文章!