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

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

  • PlacesService قدیمی دارای یک متد nearbySearch() است که به شما امکان می دهد مکان ها را در یک منطقه مشخص شده با کلمه کلیدی یا نوع جستجو کنید.
  • کلاس Place دارای یک متد searchNearby() است که به شما امکان می دهد مکان ها را در یک منطقه مشخص شده بر اساس نوع مکان جستجو کنید، با استفاده از انتخاب گسترده ای از فیلدهای داده مکان و انواع مکان برای انعطاف پذیری بیشتر.

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

PlacesService (قدیمی) Place (جدید)
nearbySearch()
searchNearby()
PlaceSearchRequest SearchNearbyRequest
برای رسیدگی به شیء نتایج و پاسخ google.maps.places.PlacesServiceStatus به استفاده از یک تماس پاسخ نیاز دارد. از Promises استفاده می کند و به صورت ناهمزمان کار می کند.
به بررسی PlacesServiceStatus نیاز دارد. بدون بررسی وضعیت مورد نیاز، می توان از مدیریت خطای استاندارد استفاده کرد.
فقط از تعصب موقعیت مکانی پشتیبانی می کند. از تعصب مکان و محدودیت مکان پشتیبانی می کند.
تمام فیلدهای داده موجود ( زیر مجموعه ای از فیلدهای پشتیبانی شده ) را برمی گرداند. نمی توان آن را محدود به زمینه های خاص کرد. فقط فیلدهای داده مکان درخواستی را برمی گرداند. کلاس Place مجموعه ای گسترده و مرتباً به روز شده از فیلدها را ارائه می دهد.
محدود به مجموعه ای ثابت از انواع مکان . به مجموعه ای گسترده و مرتباً به روز شده از انواع مکان ها دسترسی داشته باشید.
پشتیبانی از جستجوی متنی با کلمه کلیدی جستجوی متنی پشتیبانی نمی شود، به جای آن از جستجوی متن (جدید) استفاده کنید.

مقایسه کدها

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

جستجوی نزدیک (قدمتی)

جستجوی قدیمی Nearby به شما امکان می‌دهد مکان‌ها را در یک منطقه مشخص بر اساس کلمه کلیدی یا نوع جستجو کنید. هیچ راهی برای محدود کردن جستجوها با استفاده از فیلدهای داده مکان وجود ندارد، به طوری که تمام فیلدهای موجود با هر درخواست بازگردانده می شوند. قطعه زیر فراخوانی nearbySearch() را برای بازگرداندن اطلاعات رستوران‌های سیدنی، استرالیا نشان می‌دهد. این درخواست همزمان است، از یک تماس برگشتی استفاده می‌کند و شامل بررسی شرطی مورد نیاز در 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,
  });
}

بیشتر بدانید

جستجوی نزدیک (جدید)

نسخه جدید Nearby Search به روش‌های زیر نسبت به نسخه قبلی خود بهبود می‌یابد:

  • توانایی تعیین فیلدهای داده ای برای بازگرداندن کدام مکان.
  • استفاده از Promises که عملکرد ناهمزمان را امکان پذیر می کند.
  • بدون نیاز به بررسی وضعیت PlacesService . به جای آن می توان از مدیریت خطای استاندارد استفاده کرد.

قطعه کد زیر تابعی را نشان می دهد که درخواست جستجوی نزدیک برای رستوران ها را می دهد. این مثال استفاده از گزینه rankPreference را برای رتبه بندی نتایج جستجو بر اساس محبوبیت نشان می دهد (در نسخه قبلی رتبه بندی با استفاده از گزینه rankBy مشخص شده است). از آنجایی که متد searchNearby() از عملگر await استفاده می کند، فقط می تواند در داخل یک تابع 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");
  }
}

بیشتر بدانید