vue3中简单的使用百度地图
1、申请百度开发者账号百度地图开放平台 | 百度地图API SDK | 地图开发百度地图API是一套为开发者提供的基于百度地图的应用程序接口,包括JavaScript、iOS、Andriod、静态地图、Web服务等多种版本,提供基本地图、位置搜索、周边搜索、公交驾车导航、定位服务、地理编码及逆地理编码等丰富功能。LBS·云是百度地图针对LBS开发者全新推出的平台级服务。通过地图API,一方面解决移
·
1、申请百度开发者账号
3、 在vue入口文件index中引入
<script type="text/javascript" src="http://api.map.baidu.com/api?v=3.0&ak=获取到的AK"></script>
4、封装地图组件 在组件中使用
<template>
<div id="map" :style="{ width: width + 'px', height: height + 'px' }"></div>
</template>
<script lang="ts">
import { defineComponent, onMounted } from 'vue'
export default defineComponent({
props: {
// 传入需要定位的经纬度
latitude: {
type: Number,
default: () => {
return 31.14
},
},
longitude: {
type: Number,
default: () => {
return 118.22
},
},
width: {
type: Number,
default: 598,
},
height: {
type: Number,
default: 346,
},
},
setup(props, { emit }) {
const BMap = (window as any).BMap
onMounted(() => {
var map = new BMap.Map('map')
var point = new BMap.Point(props.longitude, props.latitude)
// var point = new BMap.Point(116.46, 39.92)
console.log(props.latitude)
console.log(props.longitude)
// console.log(point)
map.centerAndZoom(point, 15)
map.enableScrollWheelZoom(true)
map.addEventListener('click', function (e: any) {
// let a = JSON.parse(e)
console.log('点击的经纬度:' + e.point.lng + ',' + e.point.lat) //
emit('update:longitude', e.point.lng)
emit('update:latitude', e.point.lat)
})
})
},
})
</script>
<w-map :width="598" :height="346" v-model:longitude="116.46" v-model:latitude="39.92"></w-map>
更多推荐
已为社区贡献7条内容
所有评论(0)