typescript/no-unnecessary-type-arguments 의심스러움
수행하는 작업
이 규칙은 기본 타입 매개변수와 동일한 타입 인수를 사용하는 것을 금지합니다.
왜 나쁜가요?
기본값과 동일한 타입 인수를 명시적으로 지정하는 것은 불필요하며 코드에 시각적 잡음을 추가합니다. TypeScript는 이러한 타입을 자동으로 추론합니다.
예시
이 규칙에 부적절한 코드 예시:
ts
function identity<T = string>(arg: T): T {
return arg;
}
// 불필요한 타입 인수 - string은 기본값입니다
const result = identity<string>("hello");
interface Container<T = number> {
value: T;
}
// 불필요한 타입 인수 - number는 기본값입니다
const container: Container<number> = { value: 42 };
class MyClass<T = boolean> {
constructor(public value: T) {}
}
// 불필요한 타입 인수 - boolean은 기본값입니다
const instance = new MyClass<boolean>(true);이 규칙에 적절한 코드 예시:
ts
function identity<T = string>(arg: T): T {
return arg;
}
// 기본 타입 사용
const result1 = identity("hello");
// 다른 타입 사용
const result2 = identity<number>(42);
interface Container<T = number> {
value: T;
}
// 기본 타입 사용
const container1: Container = { value: 42 };
// 다른 타입 사용
const container2: Container<string> = { value: "hello" };사용 방법
구성 파일 또는 커맨드 라인에서 이 규칙을 활성화하려면 다음을 사용할 수 있습니다:
json
{
"rules": {
"typescript/no-unnecessary-type-arguments": "error"
}
}bash
oxlint --type-aware --deny typescript/no-unnecessary-type-arguments