Vue引入高德地图并触发实现多个标点的示例详解
更新时间:2022年05月28日 10:02:27 作者:张清悠
这篇文章主要介绍了Vue引入高德地图并触发实现多个标点,主要是在public下的index.html中引入地图,引入组件设置宽高100%,本文通过示例代码给大家介绍的非常详细,需要的朋友可以参考下
1、 在public下的index.html中引入地图
<link rel="stylesheet" href="https://cache.amap.com/lbs/static/main1119.css" rel="external nofollow" /> <script src="https://webapi.amap.com/maps?v=1.4.15&key=申请的key"></script>
2、引入组件设置宽高100%
<template> <div> <div id="container" style="width: 100%;height: 550px"></div> </div> </template>
3、数组形式数据固定(一)
<script> export default { data() { return { //要标记的所有点的经纬度 lnglats: [ [108.909074, 34.254225], [108.910766, 34.254348], [108.910495, 34.253531], [108.909502, 34.253571], ], } }, mounted() { this.carGPSIP() }, methods: { carGPSIP() { var map = new AMap.Map("container", {resizeEnable: true});//初始化地图 //信息窗口实例 var infoWindow = new AMap.InfoWindow({offset: new AMap.Pixel(0, -30)}); //遍历生成多个标记点 for (var i = 0, marker; i < this.lnglats.length; i++) { var marker = new AMap.Marker({ position: this.lnglats[i],//不同标记点的经纬度 map: map }); marker.content = '我是第' + (i + 1) + '个Marker'; marker.on('click', markerClick); marker.emit('click', {target: marker});//默认初始化不出现信息窗体,打开初始化就出现信息窗体 } function markerClick(e) { infoWindow.setContent(e.target.content); infoWindow.open(map, e.target.getPosition()); } map.setFitView(); } }, } </script>
4、用ajax请求后端真是接口(二)
<template> <div id="container" style="width: 100%;height: 550px"></div> <!-- 设置宽和高 --> </template> <script> export default { data() { return { //要标记的所有点的经纬度 Coordinate:[] // Coordinate:[ // { // lng:"54.323243", // lat:"43.654322" // } // ] //后端返回的数据格式 } }, mounted() { this.carGPSIP() }, methods: { carGPSIP() { var map = new AMap.Map("container", {resizeEnable: true});//初始化地图 //信息窗口实例 var infoWindow = new AMap.InfoWindow({offset: new AMap.Pixel(0, -30)}); //遍历生成多个标记点 因后端返回是map格式因此需要判断code $ajax.positionType({}, ({ code, data }) => { if (code == 200) { console.log(data); this. Coordinate = data.deviceList; //拿到数据 let Coordinate = data.deviceList; //定义Coordinate for (var i = 0; i < this. Coordinate.length; i++) { var marker = new AMap.Marker({ position: new AMap.LngLat( Coordinate[i].lng, Coordinate[i].lat), //不同标记点的经纬度 map: map, }); marker.content = '我是第' + (i + 1) + '个Marker'; marker.on("click", markerClick); marker.emit("click", { target: marker }); //默认初始化不出现信息窗体,打开初始化就出现信息窗体 } function markerClick(e) { infoWindow.setContent(e.target.content); infoWindow.open(map, e.target.getPosition()); } map.setFitView(); } }); function markerClick(e) { infoWindow.setContent(e.target.content); infoWindow.open(map, e.target.getPosition()); } map.setFitView(); } }, } </script> <style> </style>
5、其他需求请看文档请看官方文档
综上就是简答使用高德地图分全部过程,具体需求请参照高德官方api
到此这篇关于Vue引入高德地图并触发实现多个标点的文章就介绍到这了,更多相关vue高德地图触发多个标点内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
ElementUI中<el-form>标签中ref、:model、:rules的作用浅析
Element官方文档中写到,model是表单数据对象,rules是表单验证规则,下面这篇文章主要给大家介绍了关于ElementUI中<el-form>标签中ref、:model、:rules作用的相关资料,需要的朋友可以参考下2023-01-01
最新评论