이 코드를 작성했습니다
interface Foo {
abcdef: number;
}
let x: Foo | string;
if (x instanceof Foo) {
// ...
}
그러나 TypeScript는 다음과 같은 오류를주었습니다.
'Foo' only refers to a type, but is being used as a value here.
왜 이런 일이 발생합니까? instanceof
내 값에 주어진 유형이 있는지 확인할 수 있다고 생각 했지만 TypeScript는 이것을 좋아하지 않는 것 같습니다.
답변
무슨 일이야
문제는 즉 instanceof
자바 스크립트에서 구조체이며, 자바 스크립트, instanceof
기대 값 우측 피연산자한다. 특히 x instanceof Foo
JavaScript Foo.prototype
에서는 .NET Framework의 프로토 타입 체인에 존재 하는지 여부를 확인하기 위해 런타임 검사를 수행합니다 x
.
그러나 TypeScript에서 interface
s에는 방출이 없습니다. 즉 , 런타임에 존재 Foo
하거나 Foo.prototype
존재 하지 않으므로이 코드는 확실히 실패합니다.
TypeScript는 이것이 결코 작동 하지 않을 수 있음을 알려줍니다 . Foo
유형일 뿐이며 전혀 값이 아닙니다!
“대신 무엇을 할 수 instanceof
있습니까?”
유형 가드 및 사용자 정의 유형 가드를 살펴볼 수 있습니다 .
“하지만 방금에서로 전환 interface
하면 class
어떨까요?”
당신은 전환 유혹 할 수있는 interface
A와 class
,하지만 당신은 타이프 라이터의 구조 형식 시스템에서 그 (것은 주로 어디에 실현해야한다 기반 셰이프 ), 주어진 클래스와 같은 모양이있는 객체를 생성 할 수 있습니다 :
class C {
a: number = 10;
b: boolean = true;
c: string = "hello";
}
let x = new C()
let y = {
a: 10, b: true, c: "hello",
}
// Works!
x = y;
y = x;
이 경우, 당신은 x
과 y
같은 유형이,하지만 사용하려고하면 instanceof
둘 중 하나에, 당신은 다른 한편으로는 반대의 결과를 얻을 수 있습니다. 그래서 instanceof
하지 않습니다 정말 당신이 타이프의 구조 유형을 활용하는 경우 유형에 대해 많이 말한다.
답변
인터페이스로 런타임에 유형 검사를 수행하려면 검사 하려는 인터페이스에 다른 속성 / 기능 이있는 경우 유형 guards를 사용 합니다.
예
let pet = getSmallPet();
if ((pet as Fish).swim) {
(pet as Fish).swim();
} else if ((pet as Bird).fly) {
(pet as Bird).fly();
}
답변
Daniel Rosenwasser가 옳고 멋질 수도 있지만 그의 대답을 수정하고 싶습니다. x의 인스턴스를 완전히 확인할 수 있습니다. 코드 조각을 참조하십시오.
그러나 x = y를 할당하는 것도 똑같이 쉽습니다. 이제 y는 C의 모양 만 가졌으므로 x는 C의 인스턴스가 아닙니다.
class C {
a: number = 10;
b: boolean = true;
c: string = "hello";
}
let x = new C()
let y = {
a: 10, b: true, c: "hello",
}
console.log('x is C? ' + (x instanceof C)) // return true
console.log('y is C? ' + (y instanceof C)) // return false
답변
ur 파일이 올바른 유형인지 확인하십시오. 태그는 js 파일에서는 허용되지 않지만 jsx에서는 허용됩니다.