2016-03-18 7 views
7

मेरे पास एक वेबपृष्ठ है जहां मैं दोनों जगह स्वत: पूर्ण और मार्कर के साथ Google मानचित्र का उपयोग करना चाहता हूं। उपयोगकर्ता स्वतः पूर्ण स्थान पर एक पते की खोज कर सकते हैं। मार्कर के लिए लेट-लांग डेटा डीबी से आता है और यह नहीं बदलता है। समस्या या तो नक्शा काम करता है या स्वतः पूर्ण होता है, लेकिन दोनों नहीं, और समस्या कॉलबैक से संबंधित है।उसी HTML पृष्ठ पर initMap और initAutocomplete का उपयोग करना Google मानचित्र

गूगल डॉक्स से, मैं अलग API कॉल में दोनों कॉलबैक शामिल किया है:

<script src="https://maps.googleapis.com/maps/api/js?key=[API KEY]&signed_in=true&libraries=places&callback=initAutocomplete" async defer></script> 
<script async defer src="https://maps.googleapis.com/maps/api/js?key=[API KEY]&callback=initMap"></script> 

लेकिन इस कंसोल पर त्रुटि फेंकता है, और कुछ भी नहीं काम करता है।

मेरा प्रश्न है: Google API में कितने कॉलबैक पास किए जा सकते हैं?

आपकी मदद की अत्यधिक सराहना करते हैं।

धन्यवाद

+0

कृपया एक [न्यूनतम, पूर्ण, परीक्षण और पढ़ने योग्य उदाहरण] (http://stackoverflow.com/help/mcve) प्रदान करें जो आपकी समस्या का प्रदर्शन करता है। – geocodezip

+0

क्या त्रुटियां? त्रुटियों के अस्तित्व का सिर्फ ज्ञान हमें थोड़ी सी मदद करने में हमारी सहायता नहीं करता है। –

+0

मेरी ईमानदारी से माफी यूसुफ। त्रुटि: आपने इस पृष्ठ पर Google मानचित्र API कई बार शामिल किया है। इससे अप्रत्याशित त्रुटियां हो सकती हैं। – nirvana74v

उत्तर

13

आप एक से अधिक कॉलबैक नहीं जोड़ सकते हैं (और आप एपीआई एक बार से अधिक शामिल नहीं होना चाहिए)। सभी कोड को एक कॉलबैक में रखें।

<script src="https://maps.googleapis.com/maps/api/js?key=[API KEY]&signed_in=true&libraries=places&callback=initialize" async defer></script> 

function initialize() { 
    initMap(); 
    initAutoComplete(); 
} 

या देखना this example in the documentation

function initialize() { 
 
    initMap(); 
 
    initAutocomplete(); 
 
} 
 
var map, marker; 
 

 
function initMap() { 
 
    map = new google.maps.Map(document.getElementById('map'), { 
 
     center: { 
 
     lat: -34.397, 
 
     lng: 150.644 
 
     }, 
 
     zoom: 8 
 
    }); 
 
    } 
 
    // This example displays an address form, using the autocomplete feature 
 
    // of the Google Places API to help users fill in the information. 
 

 
// This example requires the Places library. Include the libraries=places 
 
// parameter when you first load the API. For example: 
 
// <script src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&libraries=places"> 
 

 
var placeSearch, autocomplete; 
 
var componentForm = { 
 
    street_number: 'short_name', 
 
    route: 'long_name', 
 
    locality: 'long_name', 
 
    administrative_area_level_1: 'short_name', 
 
    country: 'long_name', 
 
    postal_code: 'short_name' 
 
}; 
 

 
function initAutocomplete() { 
 
    // Create the autocomplete object, restricting the search to geographical 
 
    // location types. 
 
    autocomplete = new google.maps.places.Autocomplete(
 
    /** @type {!HTMLInputElement} */ 
 
    (document.getElementById('autocomplete')), { 
 
     types: ['geocode'] 
 
    }); 
 

 
    // When the user selects an address from the dropdown, populate the address 
 
    // fields in the form. 
 
    autocomplete.addListener('place_changed', fillInAddress); 
 
} 
 

 
function fillInAddress() { 
 
    // Get the place details from the autocomplete object. 
 
    var place = autocomplete.getPlace(); 
 
    if (place.geometry.viewport) { 
 
    map.fitBounds(place.geometry.viewport); 
 
    } else { 
 
    map.setCenter(place.geometry.location); 
 
    map.setZoom(17); // Why 17? Because it looks good. 
 
    } 
 
    if (!marker) { 
 
    marker = new google.maps.Marker({ 
 
     map: map, 
 
     anchorPoint: new google.maps.Point(0, -29) 
 
    }); 
 
    } else marker.setMap(null); 
 
    marker.setOptions({ 
 
    position: place.geometry.location, 
 
    map: map 
 
    }); 
 

 
    for (var component in componentForm) { 
 
    document.getElementById(component).value = ''; 
 
    document.getElementById(component).disabled = false; 
 
    } 
 

 
    // Get each component of the address from the place details 
 
    // and fill the corresponding field on the form. 
 
    for (var i = 0; i < place.address_components.length; i++) { 
 
    var addressType = place.address_components[i].types[0]; 
 
    if (componentForm[addressType]) { 
 
     var val = place.address_components[i][componentForm[addressType]]; 
 
     document.getElementById(addressType).value = val; 
 
    } 
 
    } 
 
} 
 

 
// Bias the autocomplete object to the user's geographical location, 
 
// as supplied by the browser's 'navigator.geolocation' object. 
 
function geolocate() { 
 
    if (navigator.geolocation) { 
 
    navigator.geolocation.getCurrentPosition(function(position) { 
 
     var geolocation = { 
 
     lat: position.coords.latitude, 
 
     lng: position.coords.longitude 
 
     }; 
 
     var circle = new google.maps.Circle({ 
 
     center: geolocation, 
 
     radius: position.coords.accuracy 
 
     }); 
 
     autocomplete.setBounds(circle.getBounds()); 
 
    }); 
 
    } 
 
}
html, 
 
body { 
 
    height: 100%; 
 
    margin: 0; 
 
    padding: 0; 
 
} 
 
#map { 
 
    height: 100%; 
 
} 
 
#locationField, 
 
#controls { 
 
    position: relative; 
 
    width: 480px; 
 
} 
 
#autocomplete { 
 
    position: absolute; 
 
    top: 0px; 
 
    left: 0px; 
 
    width: 99%; 
 
} 
 
.label { 
 
    text-align: right; 
 
    font-weight: bold; 
 
    width: 100px; 
 
    color: #303030; 
 
} 
 
#address { 
 
    border: 1px solid #000090; 
 
    background-color: #f0f0ff; 
 
    width: 480px; 
 
    padding-right: 2px; 
 
} 
 
#address td { 
 
    font-size: 10pt; 
 
} 
 
.field { 
 
    width: 99%; 
 
} 
 
.slimField { 
 
    width: 80px; 
 
} 
 
.wideField { 
 
    width: 200px; 
 
} 
 
#locationField { 
 
    height: 20px; 
 
    margin-bottom: 2px; 
 
}
<div id="locationField"> 
 
    <input id="autocomplete" placeholder="Enter your address" onFocus="geolocate()" type="text" /> 
 
</div> 
 

 
<table id="address"> 
 
    <tr> 
 
    <td class="label">Street address</td> 
 
    <td class="slimField"> 
 
     <input class="field" id="street_number" disabled="true" /> 
 
    </td> 
 
    <td class="wideField" colspan="2"> 
 
     <input class="field" id="route" disabled="true" /> 
 
    </td> 
 
    </tr> 
 
    <tr> 
 
    <td class="label">City</td> 
 
    <td class="wideField" colspan="3"> 
 
     <input class="field" id="locality" disabled="true" /> 
 
    </td> 
 
    </tr> 
 
    <tr> 
 
    <td class="label">State</td> 
 
    <td class="slimField"> 
 
     <input class="field" id="administrative_area_level_1" disabled="true" /> 
 
    </td> 
 
    <td class="label">Zip code</td> 
 
    <td class="wideField"> 
 
     <input class="field" id="postal_code" disabled="true" /> 
 
    </td> 
 
    </tr> 
 
    <tr> 
 
    <td class="label">Country</td> 
 
    <td class="wideField" colspan="3"> 
 
     <input class="field" id="country" disabled="true" /> 
 
    </td> 
 
    </tr> 
 
</table> 
 
<div id="map"></div> 
 
<script src="https://maps.googleapis.com/maps/api/js?libraries=places&callback=initialize" defer></script>

+0

@geocodezip: मैं अपनी डीबी में लेट और एलएनजी को स्टोर करने के लिए गर्भपात कर रहा हूं? एमी सुझाव यह मूल्य कैसे प्राप्त करें? – Mamulasa

0

आप एक lifesaver @geocodezip हैं। मेरे पास @ goecodezip के उत्तर पर जारी रखने के लिए पर्याप्त टिप्पणी नहीं है, मेरा नक्शा स्वतः पूर्ण के साथ काम नहीं करेगा और मैंने पाया कि एचटीएमएल मंदिर का उपयोग अवैध था <!DOCTYPE HTML> जिसके कारण नक्शा नहीं हुआ दिखाई देते हैं।

अपने डीबी, सेटअप के लिए दो छिपे हुए इनपुट क्षेत्रों में अक्षां और लंबे समय तक भंडारण के बारे में टिप्पणी @Mamulasa में अपने प्रश्न का उत्तर देने अक्षां और देशांतर:

<input type="hidden" id="latitude" name="lat" value=""> 
<input type="hidden" id="longitude" name="lon" value=""> 

और ऐड ऊपर @ geocodezip के उदाहरण में:

document.getElementById ("अक्षांश")। Value = place.geometry.location.lat(); document.getElementById ("देशांतर")। Value = place.geometry.location.lng(); एक <form method="post"> में

function fillInAddress() { 
    // Get the place details from the autocomplete object. 
    var place = autocomplete.getPlace(); 
    if (place.geometry.viewport) { 
    map.fitBounds(place.geometry.viewport); 
    } else { 
    map.setCenter(place.geometry.location); 
    map.setZoom(17); // Why 17? Because it looks good. 
    } 
    if (!marker) { 
    marker = new google.maps.Marker({ 
     map: map, 
     anchorPoint: new google.maps.Point(0, -29) 
    }); 
    } else marker.setMap(null); 
    marker.setOptions({ 
    position: place.geometry.location, 
    map: map 
    }); 

    for (var component in componentForm) { 
    document.getElementById(component).value = ''; 
    document.getElementById(component).disabled = false; 
    } 

    //-- ADD LAT AND LON HERE TO APEND TO HIDDEN HTML INPUT 
    document.getElementById("latitude").value = place.geometry.location.lat(); 
    document.getElementById("longitude").value = place.geometry.location.lng(); 

    // Get each component of the address from the place details 
    // and fill the corresponding field on the form. 
    for (var i = 0; i < place.address_components.length; i++) { 
    var addressType = place.address_components[i].types[0]; 
    if (componentForm[addressType]) { 
     var val = place.address_components[i][componentForm[addressType]]; 
     document.getElementById(addressType).value = val; 
    } 
    } 
} 

लपेटें एचटीएमएल और अब आप एक छिपे हुए अक्षां और देशांतर अपने DB में स्टोर करने के लिए सहित सभी क्षेत्रों प्राप्त करने में सक्षम हो जाएगा:

fillInAddress भीतर

तो यह समारोह अब इस तरह दिखेगा ।

उम्मीद है कि इससे मदद मिलती है।

संबंधित मुद्दे