مهاجرت به جستجوی مکان جدید، مهاجرت به جستجوی مکان جدید

این صفحه تفاوت‌های بین ویژگی‌های جستجوی مکان مبتنی بر متن در کلاس Place (جدید) و PlacesService (میراث) را توضیح می‌دهد، و چند قطعه کد را برای مقایسه ارائه می‌کند.

PlacesService قدیمی دارای روش های جستجوی متنی زیر است:

  • متد findPlaceFromQuery() که یک پرس و جوی متنی را می گیرد و یک نتیجه مکان واحد را برمی گرداند و از استفاده از فیلدهای داده مکان پشتیبانی می کند.
  • متد findPlaceFromPhoneNumber() که به شما امکان می دهد مکان را با استفاده از شماره تلفن جستجو کنید و از فیلدهای داده مکان پشتیبانی می کند.
  • متد textSearch() که یک پرس و جو متنی را می گیرد و لیستی از نتایج مکان را برمی گرداند. textSearch() قدیمی‌تر است و استفاده از فیلدهای داده مکان را پشتیبانی نمی‌کند.

کلاس Place جدید متد Place.searchByText() را ارائه می دهد که به شما امکان می دهد مکان ها را با استفاده از یک پرس و جو متنی یا شماره تلفن جستجو کنید و به شما امکان می دهد جستجوهای خود را با استفاده از مجموعه گسترده ای از فیلدهای داده مکان و انواع مکان که به طور منظم به روز می شوند سفارشی کنید.

جدول زیر برخی از تفاوت های اصلی در روش های جستجوی مکان بین کلاس Place و PlacesService را فهرست می کند:

PlacesService (قدیمی) Place (جدید)
findPlaceFromQuery()
findPlaceFromPhoneNumber()
searchByText()
FindPlaceFromQueryRequest
FindPlaceFromPhoneNumberRequest
SearchByTextRequest
گزینه های پرس و جو محدود گزینه های پرس و جو گسترده تر.
برای رسیدگی به شیء نتایج و پاسخ google.maps.places.PlacesServiceStatus به استفاده از یک تماس پاسخ نیاز دارد. از Promises استفاده می کند و به صورت ناهمزمان کار می کند.
به بررسی PlacesServiceStatus نیاز دارد. بدون بررسی وضعیت مورد نیاز، می توان از مدیریت خطای استاندارد استفاده کرد.
فقط از تعصب موقعیت مکانی پشتیبانی می کند. از تعصب مکان و محدودیت مکان پشتیبانی می کند.
فیلدهای داده مکان با استفاده از snake case قالب بندی می شوند. فیلدهای داده مکان با استفاده از جعبه شتر قالب بندی می شوند.
نتیجه یک مکان را برمی‌گرداند. نتایج تا 20 مکان را برمی گرداند.
محدود به مجموعه ثابتی از انواع مکان و فیلدهای داده مکان . انتخاب گسترده ای از انواع مکان و فیلدهای داده مکان که به طور منظم به روز می شوند را ارائه می دهد.
textSearch()
searchByText()
تمام فیلدهای داده موجود ( زیر مجموعه ای از فیلدهای پشتیبانی شده ) را برمی گرداند. نمی توان آن را محدود به زمینه های خاص کرد. فقط فیلدهای داده مکان درخواستی را برمی گرداند.

مقایسه کدها

این بخش کدهای روش‌های جستجوی متن را مقایسه می‌کند تا تفاوت‌های بین سرویس Places و کلاس Place را نشان دهد. قطعه کد کد مورد نیاز در هر API مربوطه را برای درخواست جستجوی متنی نشان می دهد.

خدمات مکان‌ها (قدمتی)

قطعه کد زیر با استفاده از متد findPlaceFromQuery() برای جستجوی یک مکان را نشان می دهد. درخواست همزمان است و شامل یک بررسی مشروط در PlacesServiceStatus است. فیلدهای داده مکان مورد نیاز در بدنه درخواست مشخص شده است که قبل از درخواست واقعی تعریف شده است.

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);
    }
  });
}

بیشتر بدانید

جستجوی متن (جدید)

قطعه کد زیر با استفاده از متد searchByText() برای جستجوی مکان‌ها نشان می‌دهد. درخواست ناهمزمان است و نیازی به بررسی وضعیت ندارد (می توان از مدیریت خطای استاندارد استفاده کرد). در این مثال، درخواست شامل maxResultCount 8 است (مقدار باید بین 1 و 20 باشد). این تابع در نتایج حلقه می زند و برای هر یک نشانگر اضافه می کند و محدوده نقشه را بر اساس موقعیت نشانگرها تنظیم می کند. از آنجایی که متد searchByText() از عملگر await استفاده می کند، فقط می تواند در داخل یک تابع 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");
  }
}

متد searchByText() از گزینه‌های درخواست بیشتری در مقایسه با نسخه قبلی پشتیبانی می‌کند، از جمله:

  • includedType که به شما امکان می دهد جستجوها را به یک نوع مکان خاص محدود کنید.
  • isOpenNow که به شما امکان می دهد جستجوها را فقط به مکان هایی که باز هستند محدود کنید.
  • minRating که به شما امکان می دهد نتایج زیر حد مشخص شده را فیلتر کنید (به عنوان مثال، فقط مکان هایی با سه ستاره یا بیشتر را برگردانید).
  • locationRestriction که نتایج خارج از مکان مشخص شده را حذف می کند ( locationBias نیز پشتیبانی می شود).

بیشتر بدانید