详解vue.js下引入百度地图jsApi的两种方法


Posted in Javascript onJuly 27, 2018

前言

今天有个项目需要用到百度地图,一般我们在移动端使用百度地图,都是直接通过这样的方式,直接引入百度地图的jsApi。

<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=D9b45bc6f98deafc489e9ac1bc7f7612"></script>

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

直接引入script标签

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

//webpack.dev.conf.js

externals: {
  'BaiduMap': 'BMap'
}

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

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

webpack文档也给出了一个示例:从 CDN 引入 jQuery,而不是把它打包。

index.html

<script
 src="https://code.jquery.com/jquery-3.1.0.js"
 integrity="sha256-slogkvB1K3VOkzAI8QITxV3VzpOnkeNVsKvtkYLMjfk="
 crossorigin="anonymous">
</script>

webpack.config.js

externals: {
 jquery: 'jQuery'
}
import $ from 'jquery';

$('.my-element').animate(...);

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

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中采用的是官方的示例如

<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的。

安装

npm i vue-baidu-map --save

初始化

import Vue from 'vue'
import BaiduMap from 'vue-baidu-map'

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

使用

<template>
 <baidu-map class="map">
 </baidu-map>
</template>

<style>
/* The container of BaiduMap must be set width & height. */
.map {
 width: 100%;
 height: 300px;
}
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
java、javascript实现附件下载示例
Aug 14 Javascript
javascript将DOM节点添加到文档的方法实例分析
Aug 04 Javascript
Bootstrap嵌入jqGrid,使你的table牛逼起来
May 05 Javascript
AngularJS前端页面操作之用户修改密码功能示例
Mar 27 Javascript
vue+vuex+axios+echarts画一个动态更新的中国地图的方法
Dec 19 Javascript
从vue基础开始创建一个简单的增删改查的实例代码(推荐)
Feb 11 Javascript
Vue2.0中集成UEditor富文本编辑器的方法
Mar 03 Javascript
Vue常见面试题整理【值得收藏】
Sep 20 Javascript
angularjs实现table表格td单元格单击变输入框/可编辑状态示例
Feb 21 Javascript
微信小程序在ios下Echarts图表不能滑动的问题解决
Jul 10 Javascript
JavaScript中0、空字符串、'0'是true还是false的知识点分享
Sep 16 Javascript
JS实现的定时器展示简单秒表、页面弹框及跳转操作完整示例
Jan 26 Javascript
JavaScript中为事件指定处理程序的五种方式分析
Jul 27 #Javascript
浅谈Redux中间件的实践
Jul 27 #Javascript
JavaScript多态与封装实例分析
Jul 27 #Javascript
Vue配合iView实现省市二级联动的示例代码
Jul 27 #Javascript
react native 文字轮播的实现示例
Jul 27 #Javascript
Vue render渲染时间戳转时间,时间转时间戳及渲染进度条效果
Jul 27 #Javascript
浅析Vue项目中使用keep-Alive步骤
Jul 27 #Javascript
You might like
推荐几个开源的微信开发项目
2014/12/28 PHP
PHP+Oracle本地开发环境搭建方法详解
2019/04/01 PHP
PHP切割整数工具类似微信红包金额分配的思路详解
2019/09/18 PHP
javascript比较文档位置
2008/04/08 Javascript
利用Ext Js生成动态树实例代码
2008/09/08 Javascript
jquery 页面全选框实践代码
2010/04/02 Javascript
弹出窗口并且此窗口带有半透明的遮罩层效果
2014/03/13 Javascript
jQuery学习笔记之 Ajax操作篇(二) - 数据传递
2014/06/23 Javascript
D3.js 从P元素的创建开始(显示可加载数据)
2014/10/30 Javascript
z-blog SyntaxHighlighter 长代码无法换行解决办法(基于jquery)
2015/11/18 Javascript
跟我学习javascript的Date对象
2015/11/19 Javascript
基于MVC+EasyUI的web开发框架之使用云打印控件C-Lodop打印页面或套打报关运单信息
2016/08/29 Javascript
JS实现Ajax的方法分析
2016/12/20 Javascript
正则中的回溯定义与用法分析【JS与java实现】
2016/12/27 Javascript
微信小程序 开发之快递查询功能的实现
2017/01/09 Javascript
vue使用axios实现文件上传进度的实时更新详解
2017/12/20 Javascript
使用async、enterproxy控制并发数量的方法详解
2018/01/02 Javascript
vue 中引用gojs绘制E-R图的方法示例
2018/08/24 Javascript
[02:27]DOTA2英雄基础教程 莱恩
2014/01/17 DOTA
[01:06:19]DOTA2-DPC中国联赛定级赛 LBZS vs SAG BO3第二场 1月8日
2021/03/11 DOTA
从零学Python之入门(三)序列
2014/05/25 Python
python批量生成本地ip地址的方法
2015/03/23 Python
python 网络编程常用代码段
2016/08/28 Python
Python中的探索性数据分析(功能式)
2017/12/22 Python
使用Selenium破解新浪微博的四宫格验证码
2018/10/19 Python
Python numpy中矩阵的基本用法汇总
2019/02/12 Python
python使用Plotly绘图工具绘制水平条形图
2020/03/25 Python
利用css3实现的简单的鼠标悬停按钮
2014/11/04 HTML / CSS
伯克斯奥特莱斯:Burkes Outlet
2019/03/30 全球购物
英国工作场所设备购买网站:Slingsby
2019/05/03 全球购物
美国家庭鞋店:Shoe Sensation
2019/09/27 全球购物
中国文明网签名寄语
2014/01/18 职场文书
公职人员索取回扣检举信
2014/04/04 职场文书
假期安全教育广播稿
2014/10/04 职场文书
旷工辞退通知书
2015/04/17 职场文书