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回调的响应,因此需要在项目中安装并正确引入该库。请根据实际情况进行调整。

相关内容

热门资讯

大神推荐"wepok... 大神推荐"wepoker插件程序激活码"开挂(软件)辅助软件有挂存在-可靠技巧>>您好:软件加136...
我来教教你"wepo... 我来教教你"wepoker可以免费玩吗"开挂(透视)辅助透视证实有挂-必赢教程;无需打开直接搜索加(...
透视私人局"中至南昌... 透视私人局"中至南昌辅助工具"开挂(下载)辅助下载真实有挂-透视教程《详细加薇136704302咨询...
重要通知"八大碗辅助... 八大碗辅助器app辅助开挂教程视频分享装挂详细步骤在当今的网络游戏中,八大碗辅助器app辅助作为一种...
透视代打"江西吉安中... 江西吉安中至黑科技辅助软件开挂教程视频分享装挂详细步骤在当今的网络游戏中,江西吉安中至黑科技辅助软件...
一分钟带你了解"新上... 一分钟带你了解"新上游透视辅助"开挂(平台)辅助平台有挂讲解-必赢方法>>您好:软件加薇136704...
新手必备"中至九江脚... 中至九江脚本是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微信(...
透视总结"决战卡五星... 大家好,今天小编来为大家解答决战卡五星看牌器这个问题咨询软件客服可以免费测试直接加微信(136704...
必知教程"wpk私人... 必知教程"wpk私人局有透视吗"开挂(脚本)辅助脚本真是有挂-透明教程>>您好:软件加薇136704...
盘点几款"闲逸app... 闲逸app有脚本吗开挂教程视频分享装挂详细步骤在当今的网络游戏中,闲逸app有脚本吗作为一种经典的娱...