我有这个功能:
function getProduct(id: string){
//return some product
}
其中 id 实际上是 GUID。 Typescript 没有 guid 类型。是否可以创建类型GUID
手动?
function getProduct(id: GUID){
//return some product
}
所以如果相反'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'
将会有一些'notGuidbutJustString'
然后我会看到打字稿编译错误。
Update:正如 David Sherret 所说:无法在编译时确保基于正则表达式或其他函数的字符串值,但可以在运行时在一个地方进行所有检查。
您可以围绕字符串创建一个包装器并将其传递:
class GUID {
private str: string;
constructor(str?: string) {
this.str = str || GUID.getNewGUIDString();
}
toString() {
return this.str;
}
private static getNewGUIDString() {
// your favourite guid generation function could go here
// ex: http://stackoverflow.com/a/8809472/188246
let d = new Date().getTime();
if (window.performance && typeof window.performance.now === "function") {
d += performance.now(); //use high-precision timer if available
}
return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {
let r = (d + Math.random() * 16) % 16 | 0;
d = Math.floor(d/16);
return (c=='x' ? r : (r & 0x3 | 0x8)).toString(16);
});
}
}
function getProduct(id: GUID) {
alert(id); // alerts "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx"
}
const guid = new GUID("xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx");
getProduct(guid); // ok
getProduct("notGuidbutJustString"); // errors, good
const guid2 = new GUID();
console.log(guid2.toString()); // some guid string
Update
另一种方法是使用品牌:
type Guid = string & { _guidBrand: undefined };
function makeGuid(text: string): Guid {
// todo: add some validation and normalization here
return text as Guid;
}
const someValue = "someString";
const myGuid = makeGuid("ef3c1860-5ce6-47af-a13d-1ed72f65b641");
expectsGuid(someValue); // error, good
expectsGuid(myGuid); // ok, good
function expectsGuid(guid: Guid) {
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)