为泛型列表创建约束验证器可以通过以下步骤实现:
interface Validator<T> {
validate(item: T): boolean;
}
class NumberValidator implements Validator<number> {
validate(item: number): boolean {
// 验证规则:判断是否为数字
return typeof item === 'number';
}
}
class StringValidator implements Validator<string> {
validate(item: string): boolean {
// 验证规则:判断是否为字符串
return typeof item === 'string';
}
}
const list: Array<number | string> = [1, 2, '3', '4'];
const numberValidator = new NumberValidator();
const stringValidator = new StringValidator();
for (const item of list) {
if (numberValidator.validate(item)) {
console.log(`${item} 是一个数字`);
} else if (stringValidator.validate(item)) {
console.log(`${item} 是一个字符串`);
} else {
console.log(`${item} 不符合约束规则`);
}
}
以上代码示例中,我们定义了一个泛型接口Validator<T>
作为约束验证器的基类,然后实现了NumberValidator
和StringValidator
两个具体的约束验证器类。接着,我们创建了一个包含数字和字符串的泛型列表,并使用约束验证器对列表中的每个元素进行验证,根据验证结果输出相应的信息。
腾讯云相关产品和产品介绍链接地址:
请注意,以上链接仅供参考,具体产品选择应根据实际需求和情况进行。
领取专属 10元无门槛券
手把手带您无忧上云