Angular异步表单验证器 - 如何等待getDistanceMatrix回调的响应。
创始人
2024-10-30 11:30:43
0

在Angular中,可以使用异步表单验证器来处理等待getDistanceMatrix回调的响应。以下是一个示例解决方法:

首先,需要创建一个自定义的异步表单验证器,该验证器将等待getDistanceMatrix回调的响应。可以使用AbstractControl类的setAsyncValidators方法来添加异步验证器。

import { FormControl } from '@angular/forms';
import { Observable } from 'rxjs';
import { google } from 'google-maps';

// 自定义异步表单验证器
function distanceValidator(control: FormControl): Promise | Observable {
  return new Promise((resolve, reject) => {
    const origin = new google.maps.LatLng(37.7749, -122.4194); // 起点坐标
    const destination = control.value; // 目的地坐标

    const service = new google.maps.DistanceMatrixService();
    service.getDistanceMatrix(
      {
        origins: [origin],
        destinations: [destination],
        travelMode: 'DRIVING'
      },
      (response, status) => {
        if (status === 'OK') {
          const distance = response.rows[0].elements[0].distance;
          if (distance.value < 1000) { // 假设距离小于1000米为无效
            resolve({ invalidDistance: true });
          } else {
            resolve(null);
          }
        } else {
          resolve(null); // 如果请求失败,则继续验证
        }
      }
    );
  });
}

// 在表单控件中添加异步验证器
this.myForm = new FormGroup({
  destination: new FormControl('', [Validators.required], [distanceValidator])
});

在上面的代码中,我们创建了一个名为distanceValidator的自定义异步表单验证器。该验证器使用google-maps库的DistanceMatrixService来计算起点到目的地的距离。在回调函数中,我们根据距离的值来判断验证结果。如果距离小于1000米,我们将返回一个包含{ invalidDistance: true }的Promise;否则,我们将返回一个解析为null的Promise。

然后,我们在表单控件的初始化中,将distanceValidator添加为异步验证器。

注意:这里使用了google-maps库来演示如何等待getDistanceMatrix回调的响应,因此需要在项目中安装并正确引入该库。请根据实际情况进行调整。

相关内容

热门资讯

实测分享!德扑之星如何开房间,... 实测分享!德扑之星如何开房间,德州ai人工智能软件下载,详细教程(有挂详情)-哔哩哔哩;亲真的是有正...
九秒钟挂!微扑克德州专用辅助器... 这是一款非常优秀的德州微扑克专用 ia辅助检测软件,能够让你了解到德州微扑克专用中牌率当中全部隐藏参...
玩家必备科技!牵手跑胡子辅助收... 大家肯定在之前wpk微扑克系统发牌规律或者wpk微扑克系统发牌规律中玩过玩家必备科技!牵手跑胡子辅助...
5秒钟俱乐部!微扑克线上果真真... 5秒钟俱乐部!微扑克线上果真真的有挂,微扑克软件发牌原理,详细教程(有挂实锤)-哔哩哔哩;超受欢迎的...
2分钟细说!八闽掌上辅助软件,... 2分钟细说!八闽掌上辅助软件,红龙扑克看底牌,详细教程(有挂透明)-哔哩哔哩1、玩家可以在八闽掌上辅...
四分钟免费!微扑克真的有挂(透... 相信很多朋友都在电脑上玩过微扑克吧,但是很多朋友都在抱怨用电脑玩起来不方便。为此小编给大家带来了微扑...
透视脚本!喜扣打筒子真的有挂的... 透视脚本!喜扣打筒子真的有挂的,鱼扑克fishpoker俱乐部辅助,详细教程(有挂规律)-哔哩哔哩1...
七瞬间透明挂!微扑克发牌有问题... 七瞬间透明挂!微扑克发牌有问题(透视)外挂辅助脚本(2022已更新)(哔哩哔哩);微扑克发牌是一种具...
玩家必看科普!哈灵开挂,wep... WePoke赢率提升策略‌;玩家必看科普!哈灵开挂,wepower让系统发好牌,详细教程(有挂方法)...
八种免费!微扑克机器人代打俱乐... 八种免费!微扑克机器人代打俱乐部(辅助挂)外挂辅助脚本(2024已更新)(哔哩哔哩);亲,其实确实真...