Wyszukiwanie tekstowe (nowe) przyjmuje zapytanie tekstowe i zwraca listę pasujących miejsc.
Wyszukiwanie tekstowe (nowa funkcja) zwraca informacje o zbiorze miejsc na podstawie ciągu znaków, np. „pizza w Nowym Jorku”, „sklepy obuwnicze w pobliżu Ottawy” lub „123 Ulica Główna”. Usługa zwraca listę miejsc pasujących do ciągu tekstowego oraz wszelkich ustawionych ustawień lokalizacji. Wyszukiwanie tekstowe (nowa funkcja) umożliwia wyszukiwanie miejsc według typu, filtrowanie według kryteriów takich jak godziny otwarcia i ocena oraz ograniczanie lub faworyzowanie wyników w konkretnej lokalizacji.
Aby korzystać z wyszukiwania tekstowego (nowego), musisz włączyć „Places API (New)” w swoim projekcie Google Cloud. Więcej informacji znajdziesz w artykule Pierwsze kroki.
Wyszukiwanie miejsc na podstawie zapytania tekstowego
Zadzwoń searchByText
, aby uzyskać listę miejsc na podstawie zapytania tekstowego lub numeru telefonu.
Określ parametry wyszukiwania za pomocą żądania, a potem wywołaj funkcję searchByText()
. Wyniki są zwracane jako lista obiektów Place
, z których możesz uzyskać szczegóły miejsca. Poniższy fragment kodu pokazuje przykład żądania i wywołania funkcji searchByText
:
TypeScript
const request = { textQuery: 'Tacos in Mountain View', fields: ['displayName', 'location', 'businessStatus'], includedType: 'restaurant', locationBias: { lat: 37.4161493, lng: -122.0812166 }, isOpenNow: true, language: 'en-US', maxResultCount: 8, minRating: 3.2, region: 'us', useStrictTypeFiltering: false, }; //@ts-ignore const { places } = await Place.searchByText(request);
JavaScript
const request = { textQuery: "Tacos in Mountain View", fields: ["displayName", "location", "businessStatus"], includedType: "restaurant", locationBias: { lat: 37.4161493, lng: -122.0812166 }, isOpenNow: true, language: "en-US", maxResultCount: 8, minRating: 3.2, region: "us", useStrictTypeFiltering: false, }; //@ts-ignore const { places } = await Place.searchByText(request);
- Określ zapytanie tekstowe lub numer telefonu, aby przeprowadzić wyszukiwanie za pomocą parametru
textQuery
. - Parametr
fields
(wymagany) służy do określania oddzielonej przecinkami listy co najmniej 1 pola danych w alfabecie łacińskim. - Aby zwrócić tylko wyniki określonego typu, użyj parametru
includedType
. - Użyj tagu
locationBias
lublocationRestriction
, aby ograniczyć wyniki wyszukiwania tekstowego do konkretnego regionu.
Jeśli zapytanie zawiera numer telefonu, należy ustawić parametr region. Jeśli na przykład używasz numeru telefonu do wyszukiwania miejsca w Japonii, a żądająca domena to jp
, musisz ustawić parametr region
na „jp”. Jeśli w żądaniu nie podasz parametru region
, interfejs API domyślnie przyjmie region Stany Zjednoczone ('us').
Place
, z których możesz uzyskać szczegóły miejsca.
Przykład
W tym przykładzie używamy zapytania searchByText
, aby znaleźć restauracje serwujące taco w pobliżu Mountain View, a następnie wypełniamy mapę znacznikami, aby wyświetlić wyniki.
TypeScript
let map; let center; async function initMap() { const { Map } = await google.maps.importLibrary("maps") as google.maps.MapsLibrary; center = { lat: 37.4161493, lng: -122.0812166 }; map = new Map(document.getElementById('map') as HTMLElement, { center: center, zoom: 11, mapId: 'DEMO_MAP_ID', }); findPlaces(); } async function findPlaces() { const { Place } = await google.maps.importLibrary("places") as google.maps.PlacesLibrary; const { AdvancedMarkerElement } = await google.maps.importLibrary("marker") as google.maps.MarkerLibrary; const request = { textQuery: 'Tacos in Mountain View', fields: ['displayName', 'location', 'businessStatus'], includedType: 'restaurant', locationBias: { lat: 37.4161493, lng: -122.0812166 }, isOpenNow: true, language: 'en-US', maxResultCount: 8, minRating: 3.2, region: 'us', useStrictTypeFiltering: false, }; //@ts-ignore const { places } = await Place.searchByText(request); if (places.length) { console.log(places); const { LatLngBounds } = await google.maps.importLibrary("core") as google.maps.CoreLibrary; const bounds = new LatLngBounds(); // Loop through and get all the results. places.forEach((place) => { const markerView = new AdvancedMarkerElement({ map, position: place.location, title: place.displayName, }); bounds.extend(place.location as google.maps.LatLng); console.log(place); }); map.fitBounds(bounds); } else { console.log('No results'); } } initMap();
JavaScript
let map; let center; async function initMap() { const { Map } = await google.maps.importLibrary("maps"); center = { lat: 37.4161493, lng: -122.0812166 }; map = new Map(document.getElementById("map"), { center: center, zoom: 11, mapId: "DEMO_MAP_ID", }); findPlaces(); } async function findPlaces() { const { Place } = await google.maps.importLibrary("places"); const { AdvancedMarkerElement } = await google.maps.importLibrary("marker"); const request = { textQuery: "Tacos in Mountain View", fields: ["displayName", "location", "businessStatus"], includedType: "restaurant", locationBias: { lat: 37.4161493, lng: -122.0812166 }, isOpenNow: true, language: "en-US", maxResultCount: 8, minRating: 3.2, region: "us", useStrictTypeFiltering: false, }; //@ts-ignore const { places } = await Place.searchByText(request); if (places.length) { console.log(places); const { LatLngBounds } = await google.maps.importLibrary("core"); const bounds = new LatLngBounds(); // Loop through and get all the results. places.forEach((place) => { const markerView = new AdvancedMarkerElement({ map, position: place.location, title: place.displayName, }); bounds.extend(place.location); console.log(place); }); map.fitBounds(bounds); } else { console.log("No results"); } } initMap();
CSS
/* * Always set the map height explicitly to define the size of the div element * that contains the map. */ #map { height: 100%; } /* * Optional: Makes the sample page fill the window. */ html, body { height: 100%; margin: 0; padding: 0; }
HTML
<html> <head> <title>Text Search</title> <link rel="stylesheet" type="text/css" href="./style.css" /> <script type="module" src="./index.js"></script> </head> <body> <div id="map"></div> <!-- prettier-ignore --> <script>(g=>{var h,a,k,p="The Google Maps JavaScript API",c="google",l="importLibrary",q="__ib__",m=document,b=window;b=b[c]||(b[c]={});var d=b.maps||(b.maps={}),r=new Set,e=new URLSearchParams,u=()=>h||(h=new Promise(async(f,n)=>{await (a=m.createElement("script"));e.set("libraries",[...r]+"");for(k in g)e.set(k.replace(/[A-Z]/g,t=>"_"+t[0].toLowerCase()),g[k]);e.set("callback",c+".maps."+q);a.src=`https://maps.${c}apis.com/maps/api/js?`+e;d[q]=f;a.onerror=()=>h=n(Error(p+" could not load."));a.nonce=m.querySelector("script[nonce]")?.nonce||"";m.head.append(a)}));d[l]?console.warn(p+" only loads once. Ignoring:",g):d[l]=(f,...n)=>r.add(f)&&u().then(()=>d[l](f,...n))}) ({key: "AIzaSyB41DRUbKWJHPxaFjMAwdrzWzbVKartNGg", v: "weekly"});</script> </body> </html>