因为百度地图只能CDN加载(可能我不知道有可以本地加载的方法,如果有答主知道希望不吝赐教,非常感谢!),所以使用requirejs配置的时候,我的代码如下:
//main.js
require.config({
baseUrl: './',
paths: {
'BMap':'http://api.map.baidu.com/api?v=2.0&ak=我的密钥'
}
});
require(['MyMap'], function (MyMap) {
//...
});
但是通过这种加载方法,我希望在MyMap模块中使用百度API时,代码如下:
//MyMap.js
define(['BMap'],function(BMap){
function init() {
var map = new BMap.Map('container');
var point = new BMap.Point(116.404449, 39.914889);
map.centerAndZoom(point, 15);
map.enableScrollWheelZoom();
}
});
会提示
Cannot read property 'Map' of undefined
在chrome里查看network,发现百度API是在MyMap.js之后加载的。
点开百度API文件,如下:
(
function(){
window.BMap_loadScriptTime = (new Date).getTime();
document.write('<script type="text/javascript" src="http://api.map.baidu.com/getscript?v=2.0&ak=我的密钥"></script>');
}
)();
到底是什么问题呢?
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
既然已经定义了baiduMap的路径,那么在使用前直接引入,像这样
require(['BMap'], function (BMap) {
//...应该在这里初始化
var map = new BMap.Map('container');
var point = new BMap.Point(116.404449, 39.914889);
map.centerAndZoom(point, 15);
map.enableScrollWheelZoom();
});