我正在尝试加载特定的区域地图onRegionClick
。但是,在进行更改后,似乎区域正在加载。这是我的代码:
function switchMap(code) {
$.getScript('maps/'+ code +'.js');
$('#map').vectorMap({map: code});
}
$('#map').vectorMap({
map: 'world_mill_en',
onRegionClick: function(event, code) {
if (code == "CA") {switchMap(code)}
if (code == "AF") {switchMap(code)}
if (code == "AL") {switchMap(code)}
if (code == "AR") {switchMap(code)}
if (code == "CH") {switchMap(code)}
}
});
控制台输出是:
Uncaught Error: Attempt to use map which was not loaded: CA world-map.js:82
OPTIONS file:///C:/Users/D-4/Desktop/find-a-bible/maps/CA.js?_=1364318443130 jquery-1.8.2.js:8416
答案 0 :(得分:4)
为了使用switchMap函数,必须在文件完全加载后初始化新的vectorMap,从而在回调中初始化它。 。
function switchMap(code) {
$.getScript('maps/'+ code +'.js' , function (data){
$('#map').vectorMap({map: code});
});
}
答案 1 :(得分:1)
你应该只设置div的高度或宽度来正确渲染地图。 jvectormap将自动计算缺失的维度以维持地图纵横比。如果您使用javascript动态更改高度,请确保在地图对象上调用updateSize
。
请注意,您可以使用此var mapObject = $('#world-map-gdp').vectorMap('get', 'mapObject');
获取地图对象,然后调用mapObject.updateSize();