VueCli3引入百度地图Api详细步骤+宽高自动页面自适应(踩坑+源代码)

在这里插入图片描述

  1. 首先去百度地图官网申请ak密钥,这个很简单,百度也有很多教程,就不细说了。

    传送门:申请ak密钥
    开发文档:百度地图API开发文档

  2. 打开项目文件,在public文件夹下的index.html页面中引入百度地图API
    这里的密钥,要替换为你刚才申请的ak密钥

 <script type="text/javascript" src="http://api.map.baidu.com/getscript?v=3.0&ak=密钥"></script>

3.在src->components文件夹下新建一个vue组件,我把它命名为:BaiduMap.vue,然后贴上代码

<template>
	<div id="map" :style="{height:mapHeight}">
		<div id="allmap" ref="allmap"></div>
	</div>
</template>
<script>
	export default {
		name: "BaiduMap",
		methods: {
			map() {
				let map = new window.BMap.Map(this.$refs.allmap); // 创建Map实例
				map.centerAndZoom(new window.BMap.Point(116.404, 39.915), 11); // 初始化地图,设置中心点坐标和地图级别
				map.addControl(
					new window.BMap.MapTypeControl({
						// 添加地图类型控件
						mapTypes: [window.BMAP_NORMAL_MAP, window.BMAP_HYBRID_MAP],
					})
				);
				map.setCurrentCity("北京"); // 设置地图显示的城市 此项是必须设置的
				map.enableScrollWheelZoom(true); // 开启鼠标滚轮缩放
			},
			initMapHeight() {
				var main = document.getElementById("map");
				main.style.height = window.innerHeight + "px";
			},
		},
		data() {
			return {
				mapHeight: 800 + "px",
			};
		},
		mounted() {
			this.initMapHeight();
			this.map();
			window.onresize = () => {
				return (() => {
					this.mapHeight = window.innerHeight + 'px';
				})();
			};
		},
	};
</script>
<style>
	#allmap {
		height: 100%;
		overflow: hidden;
	}
</style>

先来解释一下上面的代码,百度地图的容器必须在有高度的div中才能进行渲染,为了实现页面自适应的效果,为id为map的父元素绑定了动态高度mapHeight,并在页面加载的时候初始化这个值,这样容器就有高度了,这个高度在页面发送变化的时候会被更新。

window.onresize = () => {
				return (() => {
					this.mapHeight = window.innerHeight + 'px';
				})();
			};

其他代码阅读开发文档后就都明白了
开发文档:百度地图API开发文档
————————————————————————————————————————————————
到这里,百度地图的组件就做好了,当你需要用它的时候把他引入相应的界面就可以了。
什么?你别告诉我你不会引入界面……

比如我们要在index.vue 中引入百度地图

  1. 在script插入如下代码
import BaiduMap from '@/components/BaiduMap.vue'

	export default {
		name: 'Index',
		components: {
			BaiduMap
		}
	}
  1. 即可在template中使用该模板
<template>
	<BaiduMap></BaiduMap>
</template>

完成
在这里插入图片描述

今天就到这里~ 我们下个bug再见

为了实现vue3+ element plus+ts的门户网站自适应布局,可以按照以下步骤进行操作: 1. 安装vue-cli并创建项目 ```shell npm install -g @vue/cli vue create vue3-elementplus-mock-echarts ``` 2. 安装element-plus和sass ```shell npm install element-plus sass sass-loader ``` 3. 在main.ts中引入element-plus和sass ```typescript import { createApp } from 'vue' import App from './App.vue' import router from './router' import store from './store' import ElementPlus from 'element-plus' import 'element-plus/lib/theme-chalk/index.css' import './assets/scss/index.scss' createApp(App).use(store).use(router).use(ElementPlus).mount('#app') ``` 4. 在App.vue中使用element-plus的Layout组件进行布局 ```vue <template> <div class="app-container"> <el-container> <el-header>Header</el-header> <el-container> <el-aside>Aside</el-aside> <el-main>Main</el-main> </el-container> <el-footer>Footer</el-footer> </el-container> </div> </template> <script lang="ts"> import { defineComponent } from 'vue' export default defineComponent({ name: 'App', }) </script> <style lang="scss" scoped> .app-container { height: 100%; display: flex; flex-direction: column; .el-container { flex: 1; height: 100%; .el-header { height: 60px; } .el-aside { width: 200px; } .el-main { flex: 1; } .el-footer { height: 60px; } } } </style> ``` 5. 在index.html中设置meta标签实现自适应布局 ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no" /> <title>vue3-elementplus-mock-echarts</title> </head> <body> <div id="app"></div> </body> </html> ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值