Przejście na nową funkcję wyszukiwania w pobliżu

Na tej stronie wyjaśniamy różnice między wyszukiwaniem w pobliżu używanym w klasie Place (nowej) i PlacesService (starszej) oraz przedstawiamy fragmenty kodu do porównania.

  • Starsza wersja usługi PlacesService zawiera metodę nearbySearch(), która umożliwia wyszukiwanie miejsc w określonym obszarze według słowa kluczowego lub typu.
  • Klasa Place ma metodę searchNearby(), która umożliwia wyszukiwanie miejsc w określonym obszarze według typu miejsca. W tym celu możesz korzystać z rozszerzonego wyboru pól danych i typów miejsc, aby uzyskać większą elastyczność.

W tej tabeli opisano niektóre główne różnice między metodami wyszukiwania w pobliżu w klasie PlacePlacesService:

PlacesService (starsza wersja) Place (nowy)
nearbySearch()
searchNearby()
PlaceSearchRequest SearchNearbyRequest
Wymaga użycia funkcji wywołania zwrotnego do obsługi obiektu wyników i odpowiedzi google.maps.places.PlacesServiceStatus. Korzysta z obietnic i działa asynchronicznie.
Wymaga sprawdzenia PlacesServiceStatus. Nie wymaga sprawdzania stanu, może używać standardowej obsługi błędów.
Obsługuje tylko ustawienie „preferowanie lokalizacji”. Obsługuje ustawienie preferencji lokalizacji i ograniczenia dotyczące lokalizacji.
Zwraca wszystkie dostępne pola danych (podzbiór obsługiwanych pól); nie można ograniczyć go do określonych pól. Zwraca tylko żądane pola danych o miejscach. Klasa Place zawiera rozszerzony i regularnie aktualizowany zestaw pól.
Ograniczone do stałego zestawu typów miejsc. Korzystaj z rozszerzonego i regularnie aktualizowanego wyboru typów miejsc.
Obsługiwane wyszukiwanie tekstowe z słowem kluczowym. Wyszukiwanie tekstowe nie jest obsługiwane. Zamiast tego użyj opcji Wyszukiwanie tekstowe (nowa).

Porównanie kodu

W tej sekcji porównujemy kod metod wyszukiwania w pobliżu, aby zilustrować różnice między usługą Places i klasą Place. Fragmenty kodu pokazują kod wymagany w każdym z tych interfejsów API, aby przesłać żądanie wyszukiwania tekstowego.

Wyszukiwanie w pobliżu (starsza wersja)

Starsza wersja wyszukiwania w pobliżu umożliwia wyszukiwanie miejsc na określonym obszarze za pomocą słowa kluczowego lub typu. Nie można ograniczać wyszukiwania za pomocą pól danych o miejscach, dlatego wszystkie dostępne pola są zwracane z każdą prośbą. Poniższy fragment kodu pokazuje wywołanie funkcji nearbySearch(), która zwraca informacje o restauracjach w Sydney w Australii. Żądanie jest synchroniczne, używa wywołania zwrotnego i zawiera wymagany warunek warunkowy PlacesServiceStatus.

let map;
let service;

function initMap() {
  const sydney = new google.maps.LatLng(-33.867, 151.195);

  map = new google.maps.Map(document.getElementById("map"), {
    center: sydney,
    zoom: 15,
  });

  const request = {
    location: sydney,
    radius: '500',
    type: ['restaurant']
  };

  service = new google.maps.places.PlacesService(map);
  service.nearbySearch(request, callback);
}

function callback(results, status) {
  if (status == google.maps.places.PlacesServiceStatus.OK) {
    for (var i = 0; i < results.length; i++) {
      createMarker(results[i]);
    }
  }
}

// Helper function to create markers.
function createMarker(place) {
  if (!place.geometry || !place.geometry.location) return;

  const marker = new google.maps.Marker({
    map,
    position: place.geometry.location,
    title: place.name,
  });
}

Więcej informacji

Wyszukiwanie w pobliżu (nowość)

Nowa wersja wyszukiwania w pobliżu jest lepsza od poprzedniej pod tymi względami:

  • Możliwość określenia, które pola danych o miejscach mają być zwracane.
  • Korzystanie z obietnic, które umożliwia działanie asynchroniczne.
  • Nie trzeba sprawdzać stanu PlacesService; można użyć standardowej obsługi błędów.

Poniższy fragment kodu pokazuje funkcję, która wysyła żądanie wyszukiwania w pobliżu dotyczące restauracji. Ten przykład pokazuje użycie opcji rankPreference do sortowania wyników wyszukiwania według popularności (w poprzedniej wersji ranking jest określany za pomocą opcji rankBy). Metoda searchNearby() używa operatora await, dlatego można jej używać tylko w ramach funkcji async.

async function nearbySearch() {
  // Restrict within the map viewport.
  let center = new google.maps.LatLng(52.369358, 4.889258);
  const request = {
    // Required parameters.
    fields: ["displayName", "location", "businessStatus"],
    locationRestriction: {
      center: center,
      radius: 500,
    },
    // Optional parameters.
    includedPrimaryTypes: ["restaurant"],
    maxResultCount: 5,
    rankPreference: google.maps.places.SearchNearbyRankPreference.POPULARITY,
    language: "en-US",
    region: "us",
  };

  const { places } = await google.maps.places.Place.searchNearby(request);

  if (places.length) {
    console.log(places);

    // Create a new bounds, which will be extended with each result.
    const bounds = new google.maps.LatLngBounds();

    // Loop through and get all the results.
    places.forEach((place) => {
      const markerView = new google.maps.marker.AdvancedMarkerElement({
        map,
        position: place.location,
        title: place.displayName,
      });

      bounds.extend(place.location);
      console.log(place);
    });
    map.fitBounds(bounds);
  } else {
    console.log("No results");
  }
}

Więcej informacji