Lời hứa

Các phương thức không đồng bộ trong API JavaScript của Google Maps trả về Lời hứa.

Hỗ trợ

API Các phương thức trả về Lời hứa
Đường đi
Distance Matrix
Độ cao
Trình mã hoá địa lý
Hình ảnh thu phóng tối đa
Địa điểm Không
Places AutocompleteService Một phần1
Chế độ xem đường phố

Cách sử dụng

Hãy xem hướng dẫn này về cách sử dụng Lời hứa hoặc các ví dụ bên dưới để thực hiện lệnh gọi phương thức không đồng bộ bằng API JavaScript của Google Maps.

Không đồng bộ và chờ

Toán tử await được dùng để chờ một Lời hứa. Bạn chỉ có thể sử dụng hàm này bên trong một hàm không đồng bộ.

const app = async () => {
  const elevationService = google.maps.ElevationService();
  const locations = [{lat: 27.986065, lng:86.922623}];

  const response = await elevationService.getElevationForLocation({locations});
  console.log(response.results);
};

app();

Sau đó, hãy bắt và cuối cùng

Đối tượng Promise có các phương thức then, catchfinally nhận hàm callback.

const elevationService = google.maps.ElevationService();
const locations = [{lat: 27.986065, lng:86.922623}];

const promise = elevationService.getElevationForLocation({locations});

promise
    .then((response) => {
      console.log(response.results);
    })
    .catch((error) => {
      console.log(error);
    });
    .finally(() => {
      console.log('done');
    });

Mẫu gọi lại không đồng bộ

Mẫu lệnh gọi lại vẫn hợp lệ và được hỗ trợ.

const elevationService = google.maps.ElevationService();
const locations = [{lat: 27.986065, lng:86.922623}];

const callback = (results, status) => {
  if (status === 'OK') {
    console.log(results);
  } else {
    // handle this case
  }
};

elevationService.getElevationForLocation({locations}, callback);

  1. Hiện tại, Promises chỉ được hỗ trợ trong getPlacePredictions()