在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
回调的响应,因此需要在项目中安装并正确引入该库。请根据实际情况进行调整。
上一篇:Angular异步编辑表单
下一篇:Angular异步调用