是否有人有任何工作代码允许使用modernizr.load或yepnope加载Google Maps API?
我可以加载JQuery& GMap3使用modernizr,但是除非我制作传统的脚本标记,否则Google Maps API不起作用。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Please help me load Google Maps API with modernizr!</title>
<style>
#map { width: 500px; height: 300px; }
</style>
<script src="/js/modernizr-2.6.2.min.js"></script>
</head>
<body>
<h1>Please help me load Google Maps API with modernizr!</h1>
<div id="map">
Placeholder
</div>
<script>
function pageInit() {
$("#map").gmap3({
map:{
options: {
center: [18.01714, -76.750113],
zoom: 15,
mapTypeId: google.maps.MapTypeId.TERRAIN,
}
}
});
}
</script>
<!-- I WANT TO REMOVE THE SCRIPT TAG BELOW AND REPLACE WITH MODERNIZR LOAD! -->
<script src="//maps.google.com/maps/api/js?sensor=false&language=en"></script>
<!-- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -->
<script>
Modernizr.load([{load: [
'//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js',
'/js/gmap.jquery-5.1.1.min.js',
],complete: function () {loaded();}},]);
function loaded() {
$(document).ready(function() {
pageInit();
});
}
</script>
</body>
</html>
逻辑逻辑告诉我在删除脚本标记后应该进行以下更改: -
Modernizr.load([{load: [
'//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js',
'//maps.google.com/maps/api/js?sensor=false&language=en',
'/js/gmap.jquery-5.1.1.min.js',
但如果我这样做了更改,地图就不会加载,我现在在Javascript控制台中收到此错误: -
Load denied by X-Frame-Options: http://maps.google.com/maps/api/js?sensor=false&language=en does not permit cross-origin framing.
答案 0 :(得分:2)
这是我能想到的最好的结果: -
<script>
Modernizr.load([{load: [
'preload!//maps.googleapis.com/maps/api/js?sensor=false&callback=loaded',
'//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js',
'/js/gmap.jquery-5.1.1.min.js',
], complete: function () {
var script = document.createElement('script');
script.type = 'text/javascript';
script.src = '//maps.googleapis.com/maps/api/js?sensor=false&callback=loaded';
document.body.appendChild(script);
}}]);
function loaded() {
$(document).ready(function() {
pageInit();
});
}
</script>
预载似乎更快!但是我认为它根据Firebug告诉我的情况两次抓取文件。
答案 1 :(得分:0)
更改Access-Control-Allow-Origin头以允许Google的页面标头的API URL将解决安全问题。
例如Apache .htaccess:
Header set Access-Control-Allow-Origin "http://maps.googleapis.com/maps/api/js*"
或通过php:
<?php header('Access-Control-Allow-Origin: http://maps.googleapis.com/maps/api/js*', true);
虽然我不是百分之百地做出这样的事情的安全后果。 Google API是一个很棒的图书馆。请参阅http://code.google.com/p/html5security/wiki/CrossOriginRequestSecurity和Processing rogue COR
旁注,我也不喜欢这个,因为它为每个请求添加了额外的标头。