详解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 相关文章推荐
Javascript实现的类似Google的Div拖动效果代码
Aug 09 Javascript
jQuery EasyUI API 中文文档 - Form表单
Oct 06 Javascript
stream.js 一个很小、完全独立的Javascript类库
Oct 28 Javascript
淘宝网提供的国内NPM镜像简介和使用方法
Apr 17 Javascript
浅谈javascript 归并方法
Jan 21 Javascript
再谈javascript常见错误及解决方法
Sep 16 Javascript
js原生日历的实例(推荐)
Oct 31 Javascript
Makefile/cmake/node-gyp中区分判断不同平台的方法
Dec 18 Javascript
Vue 权限控制的两种方法(路由验证)
Aug 16 Javascript
Node 模块原理与用法详解
May 13 Javascript
JavaScript文档加载模式以及元素获取
Jul 28 Javascript
前端如何实现动画过渡效果
Feb 05 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
人族 TERRAN 概述
2020/03/14 星际争霸
与数据库连接
2006/10/09 PHP
理解和运用PHP中的多态性[译]
2011/08/02 PHP
php实现统计网站在线人数的方法
2015/05/12 PHP
ThinkPHP自定义函数解决模板标签加减运算的方法
2015/07/03 PHP
JavaScript入门教程(5) js Screen屏幕对象
2009/01/31 Javascript
用js脚本控制asp.net下treeview的NodeCheck的实现代码
2010/03/02 Javascript
dreamweaver 安装Jquery智能提示
2011/04/02 Javascript
jQuery(1.6.3) 中css方法对浮动的实现缺陷分析
2011/09/09 Javascript
js控制frameSet示例
2013/09/10 Javascript
JQuery中$.ajax()方法参数详解及应用
2013/12/12 Javascript
JS+CSS实现鼠标经过弹出一个DIV框完整实例(带缓冲动画渐变效果)
2016/03/25 Javascript
JavaScript检测原始值、引用值、属性
2016/06/20 Javascript
最常见和最有用的字符串相关的方法详解
2017/02/06 Javascript
ES6新特性三: Generator(生成器)函数详解
2017/04/21 Javascript
Vue 项目代理设置的优化
2018/04/17 Javascript
jQuery实现的滑块滑动导航效果示例
2018/06/04 jQuery
vue2.0项目实现路由跳转的方法详解
2018/06/21 Javascript
快速解决处理后台返回json数据格式的问题
2018/08/07 Javascript
JsonProperty 的使用方法详解
2019/10/11 Javascript
Vue简单封装axios之解决post请求后端接收不到参数问题
2020/02/16 Javascript
原生js+canvas实现贪吃蛇效果
2020/08/02 Javascript
JavaScript TAB栏切换效果的示例
2020/11/05 Javascript
Vue中使用wangeditor富文本编辑的问题
2021/02/07 Vue.js
Python 创建子进程模块subprocess详解
2015/04/08 Python
网红编程语言Python将纳入高考你怎么看?
2018/06/07 Python
Tornado实现多进程/多线程的HTTP服务详解
2019/07/25 Python
python多任务之协程的使用详解
2019/08/26 Python
python基于property()函数定义属性
2020/01/22 Python
基于Python获取docx/doc文件内容代码解析
2020/02/17 Python
Python 3.9的到来到底是意味着什么
2020/10/14 Python
Paradigit比利时电脑卖场:购买笔记本、电脑、平板和外围设备
2016/11/28 全球购物
实习自我鉴定范文
2013/10/30 职场文书
企业文化建设实施方案
2014/03/22 职场文书
财产保全担保书范文
2014/04/01 职场文书
暑期家教宣传单
2015/07/14 职场文书