【通俗易懂】Vue如何使用百度地图,通过vue-baidu-map插件实现地图功能【文档使用介绍】

现在的地图组件已经是很常用的东西了,基本上都会接触到,那么如何使用呢,相信很多新手会有点懵
这里就把基础的用法说一遍,然后说一下如何看文档。这样你就可以自己去添加功能了。

效果图

我做的是PC端的
目前的基础功能就是自动定位城市,然后可以检索地点。这也是通用最常用的基础功能了。
在这里插入图片描述

第一步:先下载插件

npm install vue-baidu-map --save

第二部:全局注册一下,在main.js里面

提示:密钥不填是地图出不来的哦。

import BaiduMap from 'vue-baidu-map'
Vue.use(BaiduMap, {
  ak: '这个地方填你的ak密钥'  //这个地方是官方提供的ak密钥
})

ak密钥在哪里来呢

就是从百度地图的开放平台申请的,自己去注册一下然后申请一个ak密钥就行了。
第一步:百度搜索百度地图,进去,最下面有个开放平台点进去
在这里插入图片描述
第二部:控制台点进去
在这里插入图片描述
第三步:申请你的密钥,如果有了后,在这个里面可以看到,那个一大串的访问应用AK就是
在这里插入图片描述

先上完整代码

//我已经代码都注释了,相信应该看得懂意思。不懂得下面我们继续看文档怎么看

<template>
  <div>
    <el-card style="height: 89vh">
      <el-input
        placeholder="请输入地址"
        v-model="input3"
        class="input-with-select"
      >
        <el-button slot="append" icon="el-icon-search" @click="inputfz"
          >搜索</el-button
        >
      </el-input>
      <!-- 
    scroll-wheel-zoom是是否可以缩放
    @ready是图加载完后触发事件
    center是位置定位
    zoom是缩放大小限制
    inertial-dragging是允许惯性拖拽
   -->
      <baidu-map
        class="bm-view"
        :zoom="15"
        :center="center"
        inertial-dragging
        @ready="mapReady"
        :scroll-wheel-zoom="true"
      >
        <!-- 定位控件   anchor="BMAP_ANCHOR_BOTTOM_RIGHT"代表放在右下角 -->
        <bm-geolocation
          anchor="BMAP_ANCHOR_BOTTOM_RIGHT"
          :showAddressBar="true"
          :autoLocation="true"
        ></bm-geolocation>
        <!-- 地区检索  keyword:关键字搜索   @searchcomplete:检索完成后的回调函数   auto-viewport:检索结束后是否自动调整地图事业  -->
        <bm-local-search
          :keyword="keyword"
          @searchcomplete="search"
          :auto-viewport="true"
          class="search"
        ></bm-local-search>
        <!-- 缩放控件   anchor代表控件停靠位置   anchor="BMAP_ANCHOR_TOP_RIGHT"代表放在右上角-->
        <bm-navigation anchor="BMAP_ANCHOR_TOP_RIGHT"></bm-navigation>
      </baidu-map>
    </el-card>
  </div>
</template>

<script>
//引入组件
import {
  BaiduMap,
  BmControl,
  BmView,
  BmAutoComplete,
  BmLocalSearch,
  BmMarker,
  BmGeolocation,
} from "vue-baidu-map";
export default {
  data() {
    return {
      //定位位置信息
      center: {},
      //检索关键字
      keyword: "",
      //输入框input值
      input3: "",
    };
  },
  //需要引入的组件
  components: {
    BaiduMap,
    BmControl,
    BmView,
    BmAutoComplete,
    BmLocalSearch,
    BmMarker,
    BmGeolocation,
  },
  methods: {
    //输入框
    inputfz() {
      this.keyword = this.input3;
    },
    //地图加载后的回调
    mapReady({ BMap, map }) {
      //保存this指向,因为在百度的回调中this不指向vue
      const _this = this;
      // 获取自动定位方法
      var geolocation = new BMap.Geolocation();
      // 获取自动定位获取的坐标信息
      geolocation.getCurrentPosition(
        function (r) {
          //可以conso.log看一下这个r,他里面包含了检索到的位置信息。下面就把两个维度信息赋值给center来定位
          _this.center = {
            lng: r.point.lng,
            lat: r.point.lat,
          };
        },
        //启用高精度
        { enableHighAccuracy: true }
      );
    },
  },
};
</script>

<style scoped>
/* 给个宽高 */
.bm-view {
  height: 400px;
  width: 700px;
}
.input-with-select {
  width: 400px;
  margin-bottom: 5px;
}
.search {
  height: 300px;
  overflow: auto;
}
</style>

vue-baidu-map的文档,不懂得可以查看

vue-baidu-map文档地址:https://dafrok.github.io/vue-baidu-map/#/zh/index

注意:这个文档并没有搜索功能,无法搜索属性名直接定位到解释那边。只能通过控件名来区分。

第一步:看一下你的控件名是啥
在这里插入图片描述
第二步:文档内看这个位置,对应上的,再找属性的解释
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

看到没有,到这里大家应该看明白了吧,其实就是你们的组件名,我就不再多截图举例了,然后你们就可以对应这个控件名,找该控件下面的属性是什么意思了。

以后你们再添加功能,就文档上看,然后把对应的空间写在baidu-map内就行,然后添加对应空间的属性来添加功能。注意些这个都是小写哈,文档上空间名有大写,但是写在html内标签名统一小写。

### 如何在 LaTeX 中调整表格大小 #### 使用 `resizebox` 命令缩放表格 为了使表格适应页面宽度,可以使用 `\resizebox` 命令。此命令源自 `graphicx` 宏包,因此需先加载该宏包: ```tex \usepackage{graphicx} ``` 接着,在定义表格时应用 `\resizebox` 来指定新的尺寸。下面是一个例子,其中 `{0.8\textwidth}` 参数表示将表格按比例缩小到文本宽度的 80%[^1]。 ```tex \begin{table}[htbp] \centering \resizebox{0.8\textwidth}{!}{ \begin{tabular}{|c|c|c|} \hline Column A & Column B & Column C \\ \hline Data 1 & Data 2 & Data 3 \\ Data 4 & Data 5 & Data 6 \\ \hline \end{tabular} } \caption{Example of resized table} \label{tab:resized_table} \end{table} ``` #### 调整字体大小和行距 除了改变整个表格的比例外,还可以通过设置不同的字体大小以及增加或减少行间距来优化布局效果。例如,可以通过更改 `\arraystretch` 的值来调节行高,并利用诸如 `\small`, `\footnotesize` 等命令减小文字字号[^2]。 ```tex \renewcommand{\arraystretch}{1.2} % Adjust row height \begin{table}[htbp] \centering \small % Change font size to small \begin{tabular}{|l|r|} ... \end{tabular} \caption{Table with adjusted text and line spacing} \label{tab:text_line_spacing} \end{table} ``` #### 控制列宽与边距 对于特别宽广的数据集,可能还需要考虑手动设定每列表项之间的最小间隔距离 (`\tabcolsep`) 或者采用多栏模式下的跨页表(`longtable`)环境[^4]。 ```tex \setlength\tabcolsep{5pt} % Set column separation space ... \begin{longtable}{p{3cm}|p{7cm}} ... % Long table spanning multiple pages \end{longtable} ```
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

接口写好了吗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值