मैं एक ऐप लिख रहा हूं जो एक हाथ से निर्मित ढांचे के साथ Google मानचित्र को असीमित रूप से लोड करता है।
जब मैं नक्शे लोड करता हूं तो यह किसी भी कारण से इसे लोड नहीं करेगा और मैं Uncaught TypeError: undefined is not a function
के साथ समाप्त हो जाऊंगा। मैंने क्रोम इंस्पेक्टर की जांच की और पाया कि google.maps
एक मान्य वस्तु है, लेकिन इसमें इसकी कोई भी संपत्ति नहीं है। दस्तावेज लोड होने के बाद मैं मैन्युअल रूप से "प्रारंभिक कार्य" को कॉल करता हूं। मैं क्या गलत कर रहा हूं?!Async Google Maps API v3 अपरिभाषित कोई फ़ंक्शन नहीं है
उत्तर
आप अच्छी तरह से ज्ञात यूआरएल (http://maps.googleapis.com/maps/api/js?v=3&sensor=false)
जब आप स्क्रिप्ट फ़ाइल पर एक नज़र डालें, तो आप देखेंगे के साथ नक्शे-एपीआई अतुल्यकालिक लोड नहीं कर सकता, जिसका इस API नहीं है कि लोड हो जाता है, यह एक लोडर है जो एपीआई लोड करता है। लोडर document.write()
का उपयोग करता है, जो आपको दस्तावेज़ लोड होने के बाद बुलाए जाने पर अप्रत्याशित परिणामों का नेतृत्व करेगा।
इसके अलावा दस्तावेज़ की ऑनलोड-घटना एसिंक्रोनस लोड ऑब्जेक्ट्स की प्रतीक्षा नहीं करती है, यह बहुत तेज़ी से आ सकती है।
आप प्रारंभिक-फ़ंक्शन का आह्वान करने के लिए स्क्रिप्ट के लोड-ईवेंट का भी उपयोग नहीं कर सकते हैं, क्योंकि जब यह आग लगती है, लोडर लोड होता है, मानचित्र-एपीआई नहीं।
क्या करें:
पटकथा यूआरएल के लिए एक कॉलबैक-पैरामीटर संलग्न
http://maps.googleapis.com/maps/api/js?v=3&sensor=false&callback=initialize
अब आप एक अलग लोडर मिल (मूल्य के रूप में इनिशियलाइज़-समारोह के नाम के साथ) जो :
document.write()
- कॉल कॉलबैक-कामकाज का उपयोग नहीं करता पर (प्रारंभ) जब नक्शे-एपीआई लोड किया गया है
डेमो: http://jsfiddle.net/doktormolle/7cu2F/
टिप्पणी से संबंधित: लगता कॉलबैक एक समारोह सीधे खिड़की से जुड़ी हो गया है। ठंडा गूगल नहीं :)
एक और विकल्प है, the google-API-loader जो फ़ंक्शन-संदर्भों (फ़ंक्शन-नामों के बजाय) के उपयोग का समर्थन करता है।
नमूना है, जो अतुल्यकालिक रूप से नक्शे-एपीआई लोड करता है, लेकिन केवल जब वहाँ दस्तावेज़ में आईडी map-canvas
साथ एक तत्व है, और फिर एक नक्शा बनाता है:
window.addEventListener('load',function(){
if(document.getElementById('map-canvas')){
google.load("maps", "3",{
callback:function(){
new google.maps.Map(document.getElementById('map-canvas'), {
center: new google.maps.LatLng(0,0),
zoom: 3
});
}
});
}
},false);
body,html,#map-canvas{
height:100%;
margin:0;
padding:0;
width:100%;
}
<script src="https://www.google.com/jsapi?.js"></script>
<div id="map-canvas"></div>
ठीक है inf के लिए धन्यवाद ओ। मैं 'कॉलबैक = प्रारंभिक' का उपयोग नहीं करना चाहता था क्योंकि मैं प्रारंभिक कार्य में कुछ अतिरिक्त तर्क पारित करना चाहता था, लेकिन मुझे लगता है कि मुझे इसके आसपास काम करना होगा। – Stephen
यह वही है जो मैं – Stephen
की तलाश में था, ऐसा लगता है कि 'कॉलबैक' को सीधे विंडो से जुड़ा एक फ़ंक्शन होना चाहिए। Google को ठंडा नहीं करें :) – apneadiving
- 1. google maps api v3 कोई लेबल नहीं?
- 2. google maps api v3 - निकटतम सड़कदृश्य
- 3. google maps api v3 निकटतम दूरी से रैंक कैसे करें
- 4. Google मानचित्र API V3
- 5. Google मानचित्र API v3
- 6. Google मानचित्र API v3
- 7. Google मानचित्र API v3
- 8. Google मानचित्र API v3
- 9. Google मानचित्र API v3 - TypeError: अभिव्यक्ति का परिणाम 'google.maps.LatLng' [अपरिभाषित] एक निर्माता नहीं है
- 10. Google मानचित्र API v3
- 11. Google मानचित्र API V3
- 12. Google मानचित्र API v3
- 13. Google मानचित्र API V3
- 14. Google मानचित्र API V3
- 15. मैं Google मानचित्र API v3
- 16. ऑब्जेक्ट में Google Map markers (api v3)
- 17. Google मानचित्र v3 API - ऑटो पूर्ण (पता)
- 18. Google मानचित्र js api v3
- 19. मानचित्र प्रदर्शित नहीं होता है Google मानचित्र API V3
- 20. Google मानचित्र में Google "My Maps" Layer जोड़ें जावास्क्रिप्ट API
- 21. Google मानचित्र API v2 बनाम Google मानचित्र API v3?
- 22. Google मानचित्र API v3 स्थान खोज - कॉलबैक फ़ंक्शन
- 23. क्या हमारे पास Google मानचित्र API V3
- 24. Google स्थल API - स्थान विवरण अनुरोध अपरिभाषित
- 25. Google मानचित्र API v3 मार्कर ओवरलैपिंग
- 26. Google कैलेंडर API v3 - अद्यतन ईवेंट
- 27. Google मानचित्र API V3 से DivPixelToLatLng लगातार
- 28. Google मानचित्र API V3 - DirectionsRendererOptions और InfoWindow
- 29. Google मानचित्र API v3 नगरपालिका सीमा
- 30. Google मानचित्र API v3 सभी polylines
शायद कुछ कोड (आपका "हाथ से निर्मित ढांचा एक शुरुआत होगी)? किसी पृष्ठ का एक लिंक जो समस्या को प्रदर्शित करता है? एक jsfiddle जो करता है? – geocodezip
दस्तावेज़ीकरण पढ़ना एक अच्छी शुरुआत है [** देखें **] (https: // डेवलपर्स। google.com/maps/documentation/javascript/tutorial#asynch) –