-
Notifications
You must be signed in to change notification settings - Fork 12.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for URI style import #35749
Comments
Related: #35589
Hi @xlaywan, @fatcerberus, @MicahZoltu, @andrewbranch Hi @vladima you implemented the current |
Please, don't let this issue die. VSCode depends on TS to resolve JS modules definitions. |
This issue seems to focus on loading / using HTTP URLs. I created a more targeted issue to just support import by URL in general, without supporting module locations beyond what TS already supports today (#41730). |
Also, Node v14.13.1+ supports the |
This is also needed for Deno. Typescript mission is a superset of JavaScript and JavaScript does support loading from url/fully qualified file name (including .ts extension). Can you please add this? |
This also applies to importing from https://cdn.skypack.dev using Snowpack. At the moment, I have to add |
And another thing to mention, webpack 5 (or rollup?) supports the mix usage of Node style import and URI style import. They can bundle the Node style import and leave the URI import to the runtime so we must not split Node&URI style into two conflict parts. |
This feature would be useful for tooling that doesn't depend on node since VSCode still uses typescript to type check files we can leverage URI style imports specially now that import maps are in the play. In my case I'm providing a dev server that uses URL imports for dependencies + import maps this works just fine, but typescript projects get errors on some dependencies but as @MMK21Hub mentioned I could make the tooling grab the types from skypack and provide them to typescript in a particular *.d.ts file or in the types property in |
Node 18 is coming out with support for |
Any updates on this? |
Currently having a hard time developing for vanilla js projects because there is no typehinting for uri imports. |
Have people tried declaring the ESM URL and manually exporting the types:
// src/types.ts
declare module "https://unpkg.com/[email protected]/lodash.js" {
export * from "@types/lodash-es";
}
// src/my_other_file.ts
import lodash from "https://unpkg.com/[email protected]/lodash.js"; |
@iansinnott that unminified lodash source includes jsdoc so you shouldn't have to declare the types for it. one solution is to use the https://marketplace.visualstudio.com/items?itemName=denoland.vscode-deno extension that can import the types from remote urls |
It's 2024 and it's still not possible to do
and get intellisense in vscode. It's really unfortunate that TypeScript and VSCode requires installing modules and bundling them in order to get any help. It should be possible to use esmodules without any bundling. |
For clarity, bundling is not required, but vendoring is. Your dependencies must be available on local disk at compile time. All of my web and Node projects use native ES modules without any bundling, minification, or obfuscation. I do have a build script that copies dependencies into my app though. |
So the problem is that TypeScript, unlike the runtime, is unable to load modules over the network? |
Not all JS runtimes can import from a URI. I don't believe NodeJS can, for example. |
It is supported behind an experimental flag, which means it will be supported. https://nodejs.org/api/esm.html#https-and-http-imports The argument "Not all JS runtimes can import from a URI" is not valid, as not all runtimes can import from filesystems. Browsers for example will not do module resolution like node does, so why is TypeScript doing it? A browser will look at the presented path and that path only, it will not try to load with various extensions or in various parent folders. |
Ah, I didn't realize Node was adding URI support. I personally think this is a bad idea from a security standpoint, and I always advise everyone to load all scripts from the same server as the main page, but this is a very opinionated position so I can appreciate that not everyone agrees. |
For people watching this, esm.sh released a VS Code extension that allows this: https://marketplace.visualstudio.com/items?itemName=ije.esm-vscode Edit: Also Skypack has a guide here: https://docs.skypack.dev/skypack-cdn/code/javascript#using-skypack-urls-in-typescript |
Search Terms
browser es module import url
Suggestion
Related issues: #28985, #19942
In browser and deno, import from a "package" is different from the node style.
Currently there is no way to let TypeScript automatically map the URI to another place like
@types/*
or$DENO_DIR/deps/https/deno.land/*
The current
path
can map a simple pattern of import module specifier to another place, but in the URI style import, a more flexible way to map the URI is required.Proposal
(maybe add a new
moduleResolution: browser
)Add a new
uriPaths
that allows to map from a RegExp to a local path. It will NOT effect the emitted code. Just a way to find the type definition for those URIs.I'm willing to implement this feature but I'm not sure if TypeScript will accept this.
Use Cases
For TypeScript to find definition file for imports like
https://unpkg.com/lodash
Examples
This rule map https://unpkg.com/[email protected]/lodash.js to
@types/lodash-es
Map https://deno.land/[email protected]/http/server.ts to
$DENO_DIR/deps/https/deno.land/std/http/server.ts
.$DENO_DIR is an environment variable.
By default, on Windows, it's
~\AppData\Local\deno\deps\https\deno.land\std\http\server.ts
.By default on Linux, it is
~/.deno/deps/https/deno.land/std/http/server.ts
.Checklist
My suggestion meets these guidelines:
The text was updated successfully, but these errors were encountered: