जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की नई सुविधा पर माइग्रेट करना

यूरोपियन इकनॉमिक एरिया (ईईए) के डेवलपर

जगह के नाम अपने-आप भरने की सुविधा, Maps JavaScript API में मौजूद Places Library की एक सुविधा है. अपने ऐप्लिकेशन में, Google Maps के खोज फ़ील्ड की तरह टाइप-अहेड-सर्च की सुविधा देने के लिए, ऑटोमैटिक तरीके से पूरा होने वाली सुविधा का इस्तेमाल किया जा सकता है.

इस पेज पर, Place Autocomplete की लेगसी और नई सुविधाओं के बीच अंतर बताया गया है. दोनों वर्शन में, ऑटोकंप्लीट को इंटिग्रेट करने के दो सामान्य तरीके हैं:

ऑटोकंप्लीट प्रोग्रामैटिक इंटरफ़ेस

यहां दी गई टेबल में, Places Autocomplete Service (लेगसी) और Autocomplete Data API (नया) के बीच, प्रोग्राम के हिसाब से किसी जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के इस्तेमाल से जुड़े कुछ मुख्य अंतर बताए गए हैं:

PlacesService (लेगसी) Place (नया)
Places Autocomplete Service के बारे में जानकारी ऑटोकंप्लीट डेटा (नया) का रेफ़रंस
AutocompletionRequest AutocompleteRequest
AutocompleteService.getPlacePredictions AutocompleteSuggestion.fetchAutocompleteSuggestions
AutocompletePrediction PlacePrediction
नतीजे के ऑब्जेक्ट और PlacesServiceStatus रिस्पॉन्स को मैनेज करने के लिए, तरीकों में कॉलबैक का इस्तेमाल करना ज़रूरी है. यह Promises का इस्तेमाल करता है और एसिंक्रोनस तरीके से काम करता है.
इन तरीकों की PlacesServiceStatus जांच करना ज़रूरी है. स्टेटस की जांच करने की ज़रूरत नहीं है. स्टैंडर्ड गड़बड़ी को ठीक करने की सुविधा का इस्तेमाल किया जा सकता है. ज़्यादा जानें.
Autocomplete इंस्टेंस बनाते समय, जगह के डेटा फ़ील्ड को विकल्पों के तौर पर सेट किया जाता है. जगह की जानकारी वाले डेटा फ़ील्ड, fetchFields() को कॉल किए जाने के बाद सेट किए जाते हैं.
क्वेरी के सुझाव देने की सुविधा उपलब्ध है (सिर्फ़ SearchBox के लिए). क्वेरी के अनुमान, Autocomplete क्लास में उपलब्ध नहीं हैं.
यह जगह की जानकारी के टाइप और जगह की जानकारी के डेटा फ़ील्ड के एक तय सेट तक सीमित है. जगह के टाइप और जगह के डेटा फ़ील्ड के ज़्यादा विकल्पों का ऐक्सेस.

नीचे दी गई चीज़ों का इस्तेमाल, पुराने और नए, दोनों ऑटोकंप्लीट एपीआई करते हैं:

कोड की तुलना (प्रोग्राम के हिसाब से)

इस सेक्शन में, ऑटोकंप्लीट के लिए कोड की तुलना की गई है. इससे प्रोग्रामैटिक इंटरफ़ेस के लिए, Places API और Place क्लास के बीच के अंतर को समझने में मदद मिलती है.

ऑटोकंप्लीट की सुविधा से मिलने वाले सुझावों को वापस पाना (लेगसी)

Places API के लेगसी वर्शन की मदद से, प्रोग्राम के हिसाब से अपने-आप पूरे होने वाले सुझावों को वापस पाया जा सकता है. इससे आपको Autocomplete क्लास की तुलना में, उपयोगकर्ता इंटरफ़ेस पर ज़्यादा कंट्रोल मिलता है. इस उदाहरण में, "par" के लिए एक ही अनुरोध किया गया है. इसमें AutocompletionRequest शामिल है. इसमें इनपुट वैल्यू और अनुमान को पक्षपाती बनाने के लिए सीमाओं का एक सेट शामिल है. इस उदाहरण में, AutocompletePrediction इंस्टेंस की सूची दिखाई गई है. साथ ही, हर इंस्टेंस के बारे में जानकारी दी गई है. उदाहरण फ़ंक्शन, एक सेशन टोकन भी बनाता है और उसे अनुरोध पर लागू करता है.

function init() {
  const placeInfo = document.getElementById("prediction");
  const service = new google.maps.places.AutocompleteService();
  const placesService = new google.maps.places.PlacesService(placeInfo);
  var sessionToken = new google.maps.places.AutocompleteSessionToken();

  // Define request options.
  let request = {
    input: "par",
    sessionToken: sessionToken,
    bounds: {
      west: -122.44,
      north: 37.8,
      east: -122.39,
      south: 37.78,
    },
  }

  // Display the query string.
  const title = document.getElementById("title");
  title.appendChild(
    document.createTextNode('Place predictions for "' + request.input + '":'),
  );

  // Perform the query and display the results.
  const displaySuggestions = function (predictions, status) {
    // Check the status of the Places Service.
    if (status != google.maps.places.PlacesServiceStatus.OK || !predictions) {
      alert(status);
      return;
    }

    predictions.forEach((prediction) => {
      const li = document.createElement("li");
      li.appendChild(document.createTextNode(prediction.description));
      document.getElementById("results").appendChild(li);
    });

    const placeRequest = {
      placeId: predictions[0].place_id,
      fields: ["name", "formatted_address"],
    };

    placesService.getDetails(placeRequest, (place, status) => {
      if (status == google.maps.places.PlacesServiceStatus.OK && place) {
        placeInfo.textContent = `
          First predicted place: ${place.name} at ${place.formatted_address}`
      }
    });

  };

  // Show the results of the query.
  service.getPlacePredictions(request, displaySuggestions);
}

ऑटोकंप्लीट की सुविधा से मिलने वाले सुझावों को वापस पाना (नया)

Place क्लास की नई सुविधा से, प्रोग्राम के हिसाब से ऑटोकंप्लीट होने वाले सुझावों को भी वापस पाया जा सकता है. इससे, PlaceAutocompleteElement क्लास की तुलना में, उपयोगकर्ता इंटरफ़ेस पर ज़्यादा कंट्रोल मिलता है. यहां दिए गए उदाहरण में, "par" के लिए एक ही अनुरोध किया गया है. इसमें AutocompleteRequest शामिल है. इसमें इनपुट वैल्यू और अनुमान को बेहतर बनाने के लिए सीमाओं का एक सेट होता है. इस उदाहरण में, placePrediction इंस्टेंस की सूची दिखाई गई है. साथ ही, हर इंस्टेंस का ब्यौरा भी दिखाया गया है. उदाहरण फ़ंक्शन, एक सेशन टोकन भी बनाता है और उसे अनुरोध पर लागू करता है.

async function init() {
  let sessionToken = new google.maps.places.AutocompleteSessionToken();

  // Define request options.
  let request = {
    input: "par",
    sessionToken: sessionToken,
    locationBias: {
      west: -122.44,
      north: 37.8,
      east: -122.39,
      south: 37.78,
    },
  };

  // Display the query string.
  const title = document.getElementById("title");
  title.appendChild(
    document.createTextNode('Place predictions for "' + request.input + '":'),
  );

  // Perform the query and display the results.
  const { suggestions } =
    await google.maps.places.AutocompleteSuggestion.fetchAutocompleteSuggestions(request);

  const resultsElement = document.getElementById("results");

  for (let suggestion of suggestions) {
    const placePrediction = suggestion.placePrediction;
    const listItem = document.createElement("li");

    listItem.appendChild(
      document.createTextNode(placePrediction.text.text),
    );

    resultsElement.appendChild(listItem);
  }

  // Show the first predicted place.
  let place = suggestions[0].placePrediction.toPlace();

  await place.fetchFields({
    fields: ["displayName", "formattedAddress"],
  });

  const placeInfo = document.getElementById("prediction");

  placeInfo.textContent = `
    First predicted place: ${place.displayName} at ${place.formattedAddress}`
}

जगह के नाम के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने वाला विजेट

यहां दी गई टेबल में, Places सेवा (लेगसी) और Place क्लास (नई) के बीच, अपने-आप पूरा होने वाले विजेट के इस्तेमाल से जुड़े कुछ मुख्य अंतर बताए गए हैं:

Places Service (लेगसी) जगह (नई सुविधा)
जगह के अनुमानों के लिए, Autocomplete क्लास. जगह के अनुमानों के लिए, PlaceAutocompleteElement क्लास.
क्वेरी के अनुमानों के लिए SearchBox क्लास
का इस्तेमाल करें.
क्वेरी के अनुमान, Autocomplete क्लास में उपलब्ध नहीं हैं.
सिर्फ़ डिफ़ॉल्ट इनपुट प्लेसहोल्डर टेक्स्ट को स्थानीय भाषा में बदला जाता है. टेक्स्ट इनपुट प्लेसहोल्डर, अनुमानों की सूची का लोगो, और जगह के अनुमान ये सभी, क्षेत्र के हिसाब से स्थानीय भाषा में उपलब्ध हैं.
विजेट, खोज को तय किए गए दायरे तक सीमित करने के लिए setBounds() या autocomplete.bindTo() का इस्तेमाल करता है. साथ ही, नतीजों को तय किए गए दायरे तक सीमित करने के लिए strictBounds का इस्तेमाल करता है. विजेट, locationBias प्रॉपर्टी का इस्तेमाल करके, नतीजों को तय की गई सीमाओं के हिसाब से दिखाता है. साथ ही, locationRestriction प्रॉपर्टी का इस्तेमाल करके, खोज को तय की गई सीमाओं तक सीमित करता है.
विजेट को सिर्फ़ स्टैंडर्ड एचटीएमएल इनपुट एलिमेंट का इस्तेमाल करके इंटिग्रेट किया जा सकता है. विजेट को स्टैंडर्ड एचटीएमएल इनपुट एलिमेंट या gmp-place-autocomplete एलिमेंट का इस्तेमाल करके इंटिग्रेट किया जा सकता है.
विजेट का इस्तेमाल करते समय, उपयोगकर्ता ऐसी चीज़ों का अनुरोध कर सकते हैं जो मान्य नहीं हो सकती हैं. उदाहरण के लिए, "बिज़नीलैंड". इस मामले को साफ़ तौर पर हैंडल किया जाना चाहिए. विजेट सिर्फ़ दिए गए सुझावों के नतीजे दिखाएगा. साथ ही, वह किसी भी वैल्यू के लिए अनुरोध नहीं कर सकता. इसलिए, संभावित तौर पर अमान्य अनुरोधों को मैनेज करने की कोई ज़रूरत नहीं है.
लेगसी PlaceResult इंस्टेंस दिखाता है. यह Place इंस्टेंस दिखाता है.
जगह की जानकारी वाले डेटा फ़ील्ड, Autocomplete ऑब्जेक्ट के लिए विकल्प के तौर पर सेट किए जाते हैं. उपयोगकर्ता के किसी जगह को चुनने पर, जगह के डेटा फ़ील्ड सेट किए जाते हैं. साथ ही, fetchFields() को कॉल किया जाता है.
यह जगह की जानकारी के टाइप और जगह की जानकारी के डेटा फ़ील्ड के एक तय सेट तक सीमित है. जगह के टाइप और जगह के डेटा फ़ील्ड के ज़्यादा विकल्पों का ऐक्सेस.

कोड की तुलना (विजेट)

इस सेक्शन में, ऑटोकंप्लीट के लिए कोड की तुलना की गई है. इससे, Place Autocomplete Widget के लेगसी वर्शन और Place Autocomplete एलिमेंट के नए वर्शन के बीच के अंतर को दिखाया गया है.

जगह के नाम के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने वाला विजेट (लेगसी)

Places API, दो तरह के ऑटोमैटिक भरने वाले विजेट उपलब्ध कराता है. इन्हें Autocomplete और SearchBox क्लास का इस्तेमाल करके जोड़ा जा सकता है. हर तरह के विजेट को मैप कंट्रोल के तौर पर मैप में जोड़ा जा सकता है. इसके अलावा, इन्हें सीधे तौर पर वेब पेज में भी एम्बेड किया जा सकता है. यहां दिए गए कोड के उदाहरण में, Autocomplete विजेट को मैप कंट्रोल के तौर पर एम्बेड करने का तरीका दिखाया गया है.

  • Autocomplete विजेट कंस्ट्रक्टर दो आर्ग्युमेंट लेता है:
    • text टाइप का एचटीएमएल input एलिमेंट. यह इनपुट फ़ील्ड है. इसमें अपने-आप पूरा होने वाली सेवा, निगरानी करेगी और अपने नतीजे जोड़ेगी.
    • यह एक वैकल्पिक AutocompleteOptions आर्ग्युमेंट है. इसमें क्वेरी को सीमित करने के लिए, अन्य विकल्प तय किए जा सकते हैं.
  • बाउंड्री सेट करने के लिए, Autocomplete इंस्टेंस को मैप से साफ़ तौर पर बाइंड किया जा सकता है. इसके लिए, autocomplete.bindTo() को कॉल करें.
  • अपने-आप पूरा होने की सुविधा के विकल्पों में, जगह की जानकारी वाले डेटा फ़ील्ड तय करें.
function initMap() {
  const map = new google.maps.Map(document.getElementById("map"), {
    center: { lat: 40.749933, lng: -73.98633 },
    zoom: 13,
    mapTypeControl: false,
  });
  const card = document.getElementById("pac-card");
  const input = document.getElementById("pac-input");
  const options = {
    fields: ["formatted_address", "geometry", "name"],
    strictBounds: false,
  };

  map.controls[google.maps.ControlPosition.TOP_LEFT].push(card);

  const autocomplete = new google.maps.places.Autocomplete(input, options);

  // Bind the map's bounds (viewport) property to the autocomplete object,
  // so that the autocomplete requests use the current map bounds for the
  // bounds option in the request.
  autocomplete.bindTo("bounds", map);

  const infowindow = new google.maps.InfoWindow();
  const infowindowContent = document.getElementById("infowindow-content");

  infowindow.setContent(infowindowContent);

  const marker = new google.maps.Marker({
    map,
    anchorPoint: new google.maps.Point(0, -29),
  });

  autocomplete.addListener("place_changed", () => {
    infowindow.close();
    marker.setVisible(false);

    const place = autocomplete.getPlace();

    if (!place.geometry || !place.geometry.location) {
      // User entered the name of a Place that was not suggested and
      // pressed the Enter key, or the Place Details request failed.
      window.alert("No details available for input: '" + place.name + "'");
      return;
    }

    // If the place has a geometry, then present it on a map.
    if (place.geometry.viewport) {
      map.fitBounds(place.geometry.viewport);
    } else {
      map.setCenter(place.geometry.location);
      map.setZoom(17);
    }

    marker.setPosition(place.geometry.location);
    marker.setVisible(true);
    infowindowContent.children["place-name"].textContent = place.name;
    infowindowContent.children["place-address"].textContent =
      place.formatted_address;
    infowindow.open(map, marker);
  });
}

जगह के नाम अपने-आप पूरे होने की सुविधा देने वाला विजेट (नया)

Place क्लास, PlaceAutocompleteElement उपलब्ध कराता है. यह HTMLElement सबक्लास है. यह एक यूज़र इंटरफ़ेस (यूआई) कॉम्पोनेंट उपलब्ध कराता है. इसे मैप कंट्रोल के तौर पर मैप में जोड़ा जा सकता है या सीधे तौर पर किसी वेब पेज में एम्बेड किया जा सकता है. यहां दिए गए कोड के उदाहरण में, PlaceAutocompleteElement विजेट को मैप कंट्रोल के तौर पर एम्बेड करने का तरीका दिखाया गया है.

जगह की जानकारी अपने-आप भरने वाले विजेट को इन तरीकों से बेहतर बनाया गया है:

  • ऑटोकंप्लीट विजेट का यूज़र इंटरफ़ेस (यूआई), क्षेत्रीय स्थानीयकरण (इसमें आरटीएल भाषाएं शामिल हैं) के साथ काम करता है. यह टेक्स्ट इनपुट प्लेसहोल्डर, सुझावों की सूची के लोगो, और जगह के सुझावों के लिए काम करता है.
  • सुलभता से जुड़ी बेहतर सुविधाएं. इनमें स्क्रीन रीडर और कीबोर्ड से इंटरैक्ट करने की सुविधा शामिल है.
  • अपने-आप पूरा होने वाला विजेट, नई Place क्लास दिखाता है. इससे, दिखाए गए ऑब्जेक्ट को आसानी से हैंडल किया जा सकता है.
  • मोबाइल डिवाइसों और छोटी स्क्रीन पर बेहतर तरीके से काम करता है.
  • बेहतर परफ़ॉर्मेंस और बेहतर ग्राफ़िकल लुक.

लागू करने के तरीके में ये मुख्य अंतर होते हैं:

  • PlaceAutocompleteElement अपना इनपुट फ़ील्ड उपलब्ध कराता है. इसे एचटीएमएल या JavaScript का इस्तेमाल करके सीधे पेज में डाला जाता है. इसे मौजूदा इनपुट एलिमेंट के तौर पर उपलब्ध नहीं कराया जाता.
  • क्वेरी के अनुमान, Autocomplete क्लास में उपलब्ध नहीं हैं.
  • PlaceAutocompleteElement को PlaceAutocompleteElementOptions का इस्तेमाल करके बनाया गया है.
    • जगह के डेटा फ़ील्ड, चुनने के समय तय किए जाते हैं. ऐसा तब होता है, जब fetchFields() को कॉल किया जाता है.
  • locationBounds या locationRestriction विकल्प का इस्तेमाल करके, सीमाएं सेट करें.
let map;
let marker;
let infoWindow;

async function initMap() {
  // Request needed libraries.
  const [{ Map }, { AdvancedMarkerElement }] = await Promise.all([
    google.maps.importLibrary("marker"),
    google.maps.importLibrary("places"),
  ]);

  // Initialize the map.
  map = new google.maps.Map(document.getElementById("map"), {
    center: { lat: 40.749933, lng: -73.98633 },
    zoom: 13,
    mapId: "4504f8b37365c3d0",
    mapTypeControl: false,
  });

  const placeAutocomplete =
    new google.maps.places.PlaceAutocompleteElement({
      locationRestriction: map.getBounds(),
    });

  placeAutocomplete.id = "place-autocomplete-input";
  const card = document.getElementById("place-autocomplete-card");

  card.appendChild(placeAutocomplete);
  map.controls[google.maps.ControlPosition.TOP_LEFT].push(card);

  // Create the marker and infowindow.
  marker = new google.maps.marker.AdvancedMarkerElement({
    map,
  });
  infoWindow = new google.maps.InfoWindow({});

  // Add the gmp-select listener, and display the results on the map.
  placeAutocomplete.addEventListener("gmp-select", async ( place ) => {
    const place = event.placePrediction.toPlace();
    await place.fetchFields({
      fields: ["displayName", "formattedAddress", "location"],
    });
    // If the place has a geometry, then present it on a map.
    if (place.viewport) {
      map.fitBounds(place.viewport);
    } else {
      map.setCenter(place.location);
      map.setZoom(17);
    }

    let content =
      '<div id="infowindow-content">' +
      '<span id="place-displayname" class="title">' +
      place.displayName +
      '</span><br />' +
      '<span id="place-address">' +
      place.formattedAddress +
      '</span>' +
      '</div>';

    updateInfoWindow(content, place.location);
    marker.position = place.location;
  });
}

// Helper function to create an info window.
function updateInfoWindow(content, center) {
  infoWindow.setContent(content);
  infoWindow.setPosition(center);
  infoWindow.open({
    map,
    anchor: marker,
    shouldFocus: false,
  });
}