我使用以下代码通过使用jquery,jqueryui-map和google maps API为地图添加形状
$('#map_canvas').gmap('getCurrentPosition', function(position, status) {
if ( status === 'OK' ) {
var clientPosition = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);
$('#map_canvas').gmap('addMarker', {'position': clientPosition, 'bounds': false});
$("#map_canvas").gmap("option", "center", clientPosition);
$('#map_canvas').gmap('option', 'zoom', 14);
$('#map_canvas').gmap('addShape', 'Circle', {
'strokeColor': "#008595",
'strokeOpacity': 0.8,
'strokeWeight': 2,
'fillColor': "#008595",
'fillOpacity': 0.35,
'center': clientPosition,
'radius': 50,
'clickable': false });
}
});
我还尝试在$('#map_canvas')上调用.addShape方法。但我只得到以下错误:
Uncaught TypeError: Cannot call method 'apply' of undefined jquery.ui.map.js:46
$.a.$.fn.(anonymous function) jquery.ui.map.js:46
e.extend.each jquery.min.js:2
e.fn.e.each jquery.min.js:2
$.a.$.fn.(anonymous function) jquery.ui.map.js:40
(anonymous function) :8080:397
$.extend.getCurrentPosition
有谁知道如何解决这个问题? http://jquery-ui-map.googlecode.com/svn/trunk/demos/jquery-google-maps-geolocation.html上的例子出于某种原因起作用..我只是无法弄清楚实际的差异..也许我现在要盲目;)
谢谢,
专利
答案 0 :(得分:7)
出现同样的问题,从未提及的相同文档产生包括jquery.ui.map.overlays.js
代码说
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=true"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>
<script type="text/javascript" src="PATH_TO_PLUGIN/jquery.ui.map.js"></script>
<script type="text/javascript" src="PATH_TO_PLUGIN/jquery.ui.map.extensions.js"></script>
实际上你需要
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=true"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>
<script type="text/javascript" src="PATH_TO_PLUGIN/jquery.ui.map.js"></script>
<script type="text/javascript" src="PATH_TO_PLUGIN/jquery.ui.map.overlays.js"></script>
事实上,经过测试,它可以在没有jquery.ui.map.extensions.js
答案 1 :(得分:1)
我评论了jquery.ui.map.extensions.js并添加了jquery.ui.map.overlays.js但它没有帮助
<script type="text/javascript" charset="utf-8" src="js/jquery-1.9.1.min.js"> </script>
<script type="text/javascript" src="js/jquery.ui.map.js"></script>
<!--script type="text/javascript" src="js/jquery.ui.map.extensions.js"></script-->
<script type="text/javascript" src="js/jquery.ui.map.overlays.js"></script>
这导致Object#没有方法'getCurrentPosition'错误。
然后我取消注释了jquery.ui.map.extensions.js然后它对我有效。
<script type="text/javascript" charset="utf-8" src="js/jquery-1.9.1.min.js"> </script>
<script type="text/javascript" src="js/jquery.ui.map.js"></script>
<script type="text/javascript" src="js/jquery.ui.map.extensions.js"></script>
<script type="text/javascript" src="js/jquery.ui.map.overlays.js"></script>
无论如何感谢Moak !!它确实有帮助。
答案 2 :(得分:0)
必须是这样的:
<script type="text/javascript" src="jquery/2.1.0/jquery-2.1.0.min.js"></script>
<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=true"></script>
<script type="text/javascript" src="jquery-ui-map/3.0-rc/ui/min/jquery.ui.map.min.js"></script>
<script type="text/javascript" src="jquery-ui-map/3.0-rc/ui/jquery.ui.map.extensions.js"></script>
<script type="text/javascript" src="jquery-ui-map/3.0-rc/ui/jquery.ui.map.overlays.js"></script>