Skip to content

Allow type annotations in .js files in preparation for Type Annotations proposal #59648

Open
@sdegutis

Description

@sdegutis

πŸ” Search Terms

allow js file extension

βœ… Viability Checklist

⭐ Suggestion

Add an option to allow removing the error "[some feature] can only be used in TypeScript files"

Previous discussion: #10939

The compiler option would allow consuming .js files as if they were .ts files, but with some differences (see below). All type-checking, type-stripping, and code emitting features would remain as-is.

πŸ“ƒ Motivating Example

The Type Annotations proposal is the definite future of JavaScript.

This feature would:

  • Enable incremental adoption of the Type Annotations proposal by users
  • Enable incremental support of Type Annotations in the TypeScript compiler
  • Possibly help push that proposal forward a little more quickly by increased usage
  • Spread word that this proposal exists by gaining compiler support in tsc and its release notes

It's true that the exact syntax isn't definite yet, and it will probably be at least somewhat different than current TypeScript syntax.

However, that's exactly why adding initial support for plain TypeScript would not interfere with its eventually sealed syntax.

In other words, the initial support would simply parse it as "typed-javascript" but the TypedJavaScript parser would currently be exactly the same as the TypeScript parser for the time being, and allow gradual differentiation.

It would also be a good opportunity to allow TypedJavaScript mode to disallow namespaces, enums, constructor fields, etc.

πŸ’» Use Cases

  1. What do you want to use this for?

Writing future-ready JavaScript.

  1. What shortcomings exist with current approaches?

It doesn't take into account the pending type annotation proposal.

  1. What workarounds are you using in the meantime?

I can almost get this working with some VS Code hacks, but then tsc complains as soon as I run it.

Metadata

Metadata

Assignees

No one assigned

    Labels

    Awaiting More FeedbackThis means we'd like to hear from more people who would be helped by this featureSuggestionAn idea for TypeScript

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions