前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue.js下引入百度地图jsApi的两种方法

Vue.js下引入百度地图jsApi的两种方法

作者头像
Javanx
发布2019-12-10 17:50:04
4.6K0
发布2019-12-10 17:50:04
举报
文章被收录于专栏:web秀web秀

最直接的方式,通过script标签引入

代码语言:javascript
复制
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak="></script>

这种方法的原理,就是直接给全局widow对象添加一个BMap对象,从而可以使我们在已经加载api的页面的任何地方,使用百度地图的api。但是单单通过引入的方法,对于使用单文件组件vue+webpack开发的项目,显然是不够的。于是,通过网上查资料。这里找到了两种方法。

直接引入script标签

第一种方法是通过直接引入的方法,当然除了引入script标签还不够,要想在vue文件中使用bmap对象,还需要在webpack的配置文件中,设置外部扩展(externals属性)

代码语言:javascript
复制
externals: {
    'BaiduMap': 'BMap'
}

externales属性来自官方的解释是:

防止将某些 import 的包(package)打包到 bundle 中,而是在运行时(runtime)再去从外部获取这些扩展依赖(external dependencies)。

我们就可以在我们的项目中通过引入js文件的方法,直接使用百度地图的api。

代码语言:javascript
复制
import BaiduMap from 'BaiduMap'
export default {
    name: 'Index',
    ....
    mounted() {
        var map = new BaiduMap.Map('allmap') // 创建地图实例
        var point = new BaiduMap.Point(120.343373, 31.540212) // 创建中心点坐标
        var marker = new BaiduMap.Marker(point) // 创建标注
        map.centerAndZoom(point, 15) // 初始化地图,设置中心点坐标和地图级别
        map.addOverlay(marker) // 将标注添加到地图中
    }
}

注意这里,实例化地图api,最好要在mounted阶段进行,如果你的dom中采用的是官方的示例如

代码语言:javascript
复制
<div id="allmap"></div>

因为只有在mounted的阶段,dom才会生成并挂载。

通过模块化引入的方法

实际上百度地图官方已经开源了基于jsApi的vue和react的对应开源组件,我们可以直接通过npm安装,然后使用。 VUE:[https://github.com/Dafrok/vue-baidu-map] React:[https://github.com/huiyan-fe/react-bmap] 可参考它们在github上面的文档进行使用。这里只介绍下vue的。 (1)安装

代码语言:javascript
复制
npm i vue-baidu-map --save

(2)初始化

代码语言:javascript
复制
import Vue from 'vue'
import BaiduMap from 'vue-baidu-map'

Vue.use(BaiduMap, {
  ak: 'YOUR_APP_KEY'    //这个地方是官方提供的ak密钥
})

(3)组件使用

代码语言:javascript
复制
<template>
  <baidu-map class="map">
  </baidu-map>
</template>

<style>
/* The container of BaiduMap must be set width & height. */
.map {
  width: 100%;
  height: 300px;
}
</style>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 直接引入script标签
  • 通过模块化引入的方法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档