vue3中简单的使用百度地图

1、申请百度开发者账号

百度地图开放平台 | 百度地图API SDK | 地图开发百度地图API是一套为开发者提供的基于百度地图的应用程序接口,包括JavaScript、iOS、Andriod、静态地图、Web服务等多种版本,提供基本地图、位置搜索、周边搜索、公交驾车导航、定位服务、地理编码及逆地理编码等丰富功能。LBS·云是百度地图针对LBS开发者全新推出的平台级服务。通过地图API,一方面解决移动开发者服务器端日益增长的海量位置数据的存储维护压力,另一方面彻底解决所有LBS开发者基于位置数据的高并发检索瓶颈。https://lbsyun.baidu.com/index.php?title=%E9%A6%96%E9%A1%B52、在控制台中创建应用获取AK

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>
### 集成百度地图Vue 3TypeScript 项目 为了在 Vue 3TypeScript 的环境中成功集成百度地图 API,需遵循特定的步骤以确保组件能够正确初始化和渲染地图。 #### 安装依赖包 首先安装 `@types/baidu-map` 类型定义以及 `bmap-gl` 百度地图 JavaScript API: ```bash npm install @types/baidu-map bmap-gl --save-dev ``` 这一步骤提供了必要的类型声明文件以便于使用 TypeScript 进行开发[^1]。 #### 创建地图容器 编辑 `index.html` 文件,在其中加入一个用于承载地图的 DOM 元素。通常情况下会放置在一个具有唯一 ID 的 `<div>` 标签内: ```html <div id="container" style="width:100%; height:500px;"></div> ``` 此操作为后续的地图实例化准备好了显示区域[^2]。 #### 初始化地图实例 编写一个新的 Vue 组件来负责地图逻辑处理工作。下面是一个简单的例子展示如何利用 `mounted()` 生命周期钩子完成地图对象创建过程: ```typescript <template> <div ref="mapContainer"></div> </template> <script lang="ts"> import { defineComponent, onMounted } from &#39;vue&#39;; // 导入BMapGL命名空间下的类库 declare const BMapGL: any; export default defineComponent({ name: "BaiduMap", setup() { let mapInstance: any; onMounted(() => { // 获取DOM节点作为地图容器 const container = document.getElementById(&#39;container&#39;); if (container) { // 实例化地图并设置中心点坐标 mapInstance = new BMapGL.Map(container); // 设置初始位置为中国北京天安门广场经纬度 const point = new BMapGL.Point(116.404, 39.915); mapInstance.centerAndZoom(point, 15); // 缩放级别 // 开启鼠标滚轮缩放功能 mapInstance.enableScrollWheelZoom(true); } }); return {}; }, }); </script> <style scoped> /* 添加样式使地图占据整个父级元素 */ #container { width: 100%; height: 100vh; } </style> ``` 上述代码片段展示了怎样通过组合 Vue Composition API 来实现地图组件的功能,并且适当设置了地图的一些基本属性如视图范围、缩放比例等参数[^3]。 #### 加载API脚本 最后不要忘记引入百度地图官方提供的 JS SDK 脚本链接至 HTML 文档头部部分,这样才能让浏览器下载所需的资源从而正常运行地图插件: ```html <!-- 将您的密钥替换掉此处的AK --> <script async defer src="//api.map.baidu.com/api?v=3.0&ak=YOUR_API_KEY&type=webgl"></script> ``` 以上就是关于如何在基于 Vue 3TypeScript 构建的应用程序里嵌入百度地图服务的方法介绍。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值