Nesta página, explicamos as diferenças entre os recursos de pesquisa de lugares baseada em texto na classe Place (nova) e na PlacesService (legada) e fornecemos alguns snippets de código para comparação.
O PlacesService legado tem os seguintes métodos de pesquisa baseados em texto:
- O método findPlaceFromQuery(), que recebe uma consulta de texto e retorna um único resultado de lugar, além de oferecer suporte ao uso de campos de dados de lugar.
- O método findPlaceFromPhoneNumber(), que permite pesquisar um lugar usando um número de telefone e oferece suporte ao uso de campos de dados de lugar.
- O método textSearch(), que usa uma consulta de texto e retorna uma lista de resultados de lugares. OtextSearch()é mais antigo e não é compatível com o uso de campos de dados de lugar.
A nova classe Place oferece o método Place.searchByText(), que permite pesquisar lugares usando uma consulta de texto ou um número de telefone, além de personalizar as pesquisas com uma seleção expandida de campos de dados e tipos de lugares atualizados regularmente.
A tabela a seguir lista algumas das principais diferenças nos métodos de pesquisa de lugar
entre a classe Place e PlacesService:
| PlacesService(legado) | Place(Novo) | 
|---|---|
| findPlaceFromQuery()findPlaceFromPhoneNumber() | searchByText() | 
| FindPlaceFromQueryRequestFindPlaceFromPhoneNumberRequest | SearchByTextRequest | 
| Opções de consulta limitadas. | Opções de consulta mais abrangentes. | 
| Exige o uso de um callback para processar o objeto de resultados e a resposta google.maps.places.PlacesServiceStatus. | Usa promessas e funciona de forma assíncrona. | 
| Requer uma verificação de PlacesServiceStatus. | Nenhuma verificação de status necessária, pode usar o tratamento de erros padrão. Saiba mais. | 
| Aceita apenas o viés de local. | Tem suporte para restrição e viés de local. | 
| Os campos de dados de lugar são formatados usando snake case. | Os campos de dados de lugar são formatados usando camel case. | 
| Retorna um único resultado de lugar. | Retorna até 20 resultados de lugares. | 
| Limitado a um conjunto fixo de tipos de lugar e campos de dados de lugar. | Oferece uma seleção expandida de tipos de lugares e campos de dados de lugares atualizados regularmente. | 
| textSearch() | searchByText() | 
| Retorna todos os campos de dados disponíveis (um subconjunto dos campos aceitos) e não pode ser restringido a campos específicos. | Retorna apenas os campos de dados de lugar solicitados. | 
Comparação de código
Esta seção compara o código dos métodos de pesquisa de texto para ilustrar as diferenças entre o serviço Places e a classe Place. Os snippets mostram o código necessário em cada API para fazer uma solicitação de pesquisa baseada em texto.
Serviço do Places (legado)
O snippet de código a seguir mostra o uso do método findPlaceFromQuery() para
pesquisar um lugar. A solicitação é síncrona e inclui uma verificação condicional
em PlacesServiceStatus. Os campos de dados de lugar necessários são especificados no corpo da solicitação, que é definido antes da solicitação real.
function findPlaces() {
  const request = {
    query: "Museum of Contemporary Art Australia",
    fields: ["name", "geometry"],
  };
  // Create an instance of PlacesService.
  service = new google.maps.places.PlacesService(map);
  // Make a findPlaceFromQuery request.
  service.findPlaceFromQuery(request, (results, status) => {
    let place = results[0];
    if (status === google.maps.places.PlacesServiceStatus.OK && results) {
      if (!place.geometry || !place.geometry.location) return;
      const marker = new google.maps.Marker({
        map,
        position: place.geometry.location,
      });
      map.setCenter(place.geometry.location);
    }
  });
}
Saiba mais
- Confira o exemplo completo de código
- Consulte a documentação
- Referência da interface FindPlaceFromQueryRequest
Text Search (novo)
O snippet de código a seguir mostra o uso do método searchByText() para pesquisar
lugares. A solicitação é assíncrona e não exige uma verificação de status. O tratamento de erros padrão pode ser usado. Neste exemplo, a solicitação inclui um maxResultCount de 8 (o valor precisa estar entre 1 e 20). Essa função faz um loop pelos resultados e adiciona um marcador para cada um, ajustando os limites do mapa com base na posição dos marcadores. Como o método searchByText() usa o operador await, ele só pode ser usado em uma função async.
async function findPlaces() {
  // Define a request.
  // The `fields` property is required; all others are optional.
  const request = {
    fields: ["displayName", "location", "businessStatus"],
    textQuery: "Tacos in Mountain View",
    includedType: "restaurant",
    locationBias: { lat: 37.4161493, lng: -122.0812166 },
    isOpenNow: true,
    language: "en-US",
    maxResultCount: 8,
    minRating: 3.2,
    region: "us",
    useStrictTypeFiltering: false,
  };
  // Call searchByText passing the request.
  const { places } = await google.maps.places.Place.searchByText(request);
  // Add a marker for each result.
  if (places.length) {
    const bounds = new google.maps.LatLngBounds();
    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");
  }
}
O método searchByText() oferece suporte a muito mais opções de solicitação em comparação com a versão anterior, incluindo:
- includedType, que permite restringir as pesquisas a um tipo de lugar específico.
- isOpenNow, que permite restringir as pesquisas para retornar apenas lugares que estão abertos.
- minRating, que permite filtrar resultados abaixo do limite especificado. Por exemplo, só retornar lugares com três estrelas ou mais.
- locationRestriction, que omite resultados fora do local especificado (- locationBiastambém é compatível).
Saiba mais
- Confira o exemplo completo de código
- Consulte a documentação da Pesquisa de texto (nova)
- Consulte a referência de searchByText()