vue项目中引入地图的详细教程

第一步:在项目中安装地图插件

html 复制代码
npm i @amap/amap-jsapi-loader --save  

第二步:创建一个容器 添加id属性 (因为地图必须使用id 不能使用class)

html 复制代码
 <div id="maps"></div>

第三步:给这个容器设置宽高

css 复制代码
#maps {
  width: 100%;
  height: calc(100vh - 400px);
}

第四步:在你写的页面引入高德地图

javascript 复制代码
import AMapLoader from "@amap/amap-jsapi-loader";

第五步:加载地图

javascript 复制代码
AMapLoader.load({
  key: "你的key值",
  version: "2.0",
})
  .then((AMap) => {
    // 调用地图渲染函数
    renderMap(AMap);
  })
  .catch((e) => {
    console.error(e); //加载错误提示
  });

第六步:创建地图渲染函数,之后地图的内容都需要写在这个函数中

javascript 复制代码
const renderMap = (AMap) => {
  const map = new AMap.Map("maps");
};

第七步;设置地图的中心点和级别

javascript 复制代码
const renderMap = (AMap) => {
  const map = new AMap.Map("maps", {
    zoom: 12,
    center: [113.978255, 35.281454],
    showIndoorMap: false,
  });
};

第八步:设置点标记到地图里

javascript 复制代码
  let Marker = new AMap.Marker({
    position: new AMap.LngLat(113.978255, 35.281454),
    icon: "https://pic.imgdb.cn/item/652a9187c458853aefe93f88.png",
    offset: new AMap.Pixel(-13, -30),
  });

  map.add(Marker);

最后一步:标记点点击事件 在事件中设置信息弹窗

javascript 复制代码
 Marker.on("click", () => {
    let infoWindow = new AMap.InfoWindow({
      content: `
        <div style="padding:10px;width:200px;">
            <h2 style="font-size:16px;line-height:30px;">中国建设银行</h2>
            <span style="font-size:14px;line-height:20px;">电话:136****5865</span>
            <p style="font-size:15px;">地址:河南省新乡市红旗区XXX 中国建设银行</p>
        </div>
      `,
      offset: new AMap.Pixel(3, -25),
    });

    infoWindow.open(map, [113.978255, 35.281454]);
  });

原创作者:吴小糖

创作时间:2023.10.16

相关推荐
海盐泡泡龟1 小时前
web常见的攻击方式有哪些?如何防御?
前端·vue.js·webpack
EndingCoder3 小时前
React从基础入门到高级实战:React 基础入门 - React Hooks 入门
前端·javascript·react.js·前端框架
EndingCoder3 小时前
React从基础入门到高级实战:React 基础入门 - JSX与组件基础
前端·javascript·react.js·前端框架
Space Chars3 小时前
【大前端】使用NodeJs HTTP模块创建web服务器、SSE通讯
服务器·前端·http
Quke陆吾4 小时前
Vue框架1(vue搭建方式1,vue指令,vue实例生命周期)
前端·javascript·vue.js
苹果酱05674 小时前
Java设计模式:探索编程背后的哲学
java·vue.js·spring boot·mysql·课程设计
Oscar_02085 小时前
uniapp+ts 多环境编译
前端·vue.js·typescript·uni-app
shmily麻瓜小菜鸡5 小时前
前端项目中实现页面看起来像是浏览器缩放到了80%的效果
前端
EndingCoder5 小时前
从零基础到最佳实践:Vue.js 系列(9/10):《单元测试与端到端测试》
前端·javascript·vue.js·性能优化·单元测试·vue3
How_doyou_do5 小时前
Vue-创建应用/挂载应用/根组件模版-.vue单文件/应用配置
前端·javascript·vue.js