欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

2种在vue项目中使用百度地图的简单方法

程序员文章站 2023-09-21 13:19:25
地图在项目中用得很多,最近也用了几次,好长时间不用都记不清了,闲暇时整理了vue里使用百度地图的2种方法,方便自己查看,也分享给大家,希望可以帮助有需要的人。 普遍的...

地图在项目中用得很多,最近也用了几次,好长时间不用都记不清了,闲暇时整理了vue里使用百度地图的2种方法,方便自己查看,也分享给大家,希望可以帮助有需要的人。

普遍的方法是:

1.index.html 中引入

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

2.新建个组件maps

注意 :不要把组件命名为map,因为html中有map标签,会报错

报错:do not use built-in or reserved html elements as component id:map

3.然后就可以直接再组件了写相关代码了

mounted(){
   var map = new bmap.map('map')
   var point = new bmap.point(108.840053, 34.129522)
   map.centerandzoom(point, 14)
   //...
  }

另一个方法:

1.新建一个map.js

export function mp(ak) {
 return new promise(function (resolve, reject) {
  window.onload = function () {
   resolve(bmap)
  }
  var script = document.createelement("script");
  script.type = "text/javascript";
  script.src = "http://api.map.baidu.com/api?v=2.0&ak="+ak+"&callback=init";
  script.onerror = reject;
  document.head.appendchild(script);
 })
}

2.在需要用到的地图的vue页面中引入

import {mp} from './map.js'

3.在vue页面中调用

data:{
  return{
    ak:'1287348913029483740293'//密钥
  }
},
mounted(){
  this.$nexttick(function(){
   var _this = this;
   mp(_this.ak).then(bmap => {
    //在此调用api
   })
  }
}