百度地图再vue中的引入方式

使用方式一

1.在public->index.html引入

javascript 复制代码
<script src="http://api.map.baidu.com/api?v=2.0&ak=你的ak&callback=initBMap"></script>

ak=自己的密钥

2.若是vue2.0就是lib/webpack.base.conf.js加入以下代码,若是vue3.0就在最外层创建一个这个文件

javascript 复制代码
module.exports = {
//百度地图配置
	externals: {
		BMap: "BMap"
	}
};

3.在vue文件 mounted挂载

<div id="map" ref="map"></div>

javascript 复制代码
   mounted() {
		// const _this = this;
		var map = new window.BMap.Map("map");
		map.centerAndZoom(new window.BMap.Point(121.450474, 31.194434), 20); // 初始化地图,设置中心点坐标和地图级别
		//添加地图类型控件
		map.addControl(
		new window.BMap.MapTypeControl({
			mapTypes: [window.BMAP_NORMAL_MAP, window.BMAP_HYBRID_MAP]
		})
		);
		map.setCurrentCity("上海"); // 设置地图显示的城市 此项是必须设置的
		map.enableScrollWheelZoom(true); //开启鼠标滚轮缩放
		var point = new window.BMap.Point(121.450474, 31.194434, 15);
		var marker = new window.BMap.Marker(point); // 创建标注
		map.addOverlay(marker); // 将标注添加到地图中
		//点击标注
		marker.addEventListener(
		"click",
		 () => {
		 	 console.log('点击');
			}, true 
		);
}

去除地图logo

html 复制代码
<style type="text/css">
	.BMap_cpyCtrl {
	display: none;
	}
	.BMap_noprint {
	display: none;
}
</style>
<style type="text/css">
	.anchorBL {
	display: none;
	}
</style>

使用方式二

**

1.安装百度地图JavaScript API SDK

html 复制代码
npm install vue-baidu-map --save

2.在main.js文件中引入百度地图组件并注册它:

javascript 复制代码
import Vue from 'vue';
import BaiduMap from 'vue-baidu-map';

Vue.use(BaiduMap, {
  ak: '你的百度地图API密钥'
});

3.在Vue组件中使用百度地图。例如,在一个名为Map.vue的组件中,可以添加如下代码

javascript 复制代码
<template>
  <div>
    <baidu-map class="map" :ak="ak" @ready="handleMapReady" :center="mapCenter" :zoom="zoom">
      <bm-marker :position="markerPosition"></bm-marker>
    </baidu-map>
  </div>
</template>

<script>
export default {
  name: 'Map',
  data() {
    return {
      ak: '你的百度地图API密钥',
      mapCenter: { lng: 116.404, lat: 39.915 },
      zoom: 15,
      markerPosition: { lng: 116.404, lat: 39.915 }
    };
  },
  methods: {
    handleMapReady(map) {
      // 地图加载完成后的回调函数
      console.log('地图加载完成', map);
    }
  }
};
</script>

<style scoped>
.map {
  width: 100%;
  height: 400px;
}
</style>
相关推荐
明远湖之鱼12 分钟前
浅入理解跨端渲染:从零实现 React DSL 跨端渲染机制
前端·react native·react.js
悟忧1 小时前
规避ProseMirror React渲染差异带来的BUG
前端
小皮虾1 小时前
小程序云开发有类似 uniCloud 云对象的方案吗?有的兄弟,有的!
前端·javascript·小程序·云开发
QuantumLeap丶1 小时前
《uni-app跨平台开发完全指南》- 05 - 基础组件使用
vue.js·微信小程序·uni-app
Android疑难杂症1 小时前
鸿蒙Notification Kit通知服务开发快速指南
android·前端·harmonyos
T___T1 小时前
全方位解释 JavaScript 执行机制(从底层到实战)
前端·面试
阳懿1 小时前
meta-llama-3-8B下载失败解决。
前端·javascript·html
Qinana1 小时前
🌊 深入理解 CSS:从选择器到层叠的艺术
前端·css·程序员
IT_陈寒1 小时前
Python 3.12新特性实测:10个让你的代码提速30%的隐藏技巧 🚀
前端·人工智能·后端
闲人编程1 小时前
从零开发一个简单的Web爬虫(使用Requests和BeautifulSoup)
前端·爬虫·beautifulsoup·bs4·web·request·codecapsule