Skip to content
← Back to rules

typescript/no-unnecessary-type-arguments 의심스러움

💭 This rule requires type information.
An auto-fix is available for this rule.

수행하는 작업

이 규칙은 기본 타입 매개변수와 동일한 타입 인수를 사용하는 것을 금지합니다.

왜 나쁜가요?

기본값과 동일한 타입 인수를 명시적으로 지정하는 것은 불필요하며 코드에 시각적 잡음을 추가합니다. 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

참고 자료