-
Notifications
You must be signed in to change notification settings - Fork 367
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
Use pure ES modules #3514
Comments
This was discussed in our guild sync and @lukasholzer decided to start moving on this item. |
After discussing with @lukasholzer and @eduardoboucas, we decided on the following plan:
|
As going further with the migration it seems that we are blocked by |
@ehmicky, @erezrokah I hit some further roadblocks on the cli repository I wanted to discuss with the group. The CLI is using the require cache mechanism to serve a clean state of the functions locally when developing. When we switch to es modules this feature is not available anymore. So I'm asking you about ideas on how we can solve that. Some options came to my mind.
Please add your opinions on that one. cc @eduardoboucas |
We should do everything we can to make sure the local development experience mimics the production environment as much as possible. esbuild is not the default bundler in production, and it's unlikely it will be anytime soon, so we shouldn't use it in the CLI unless people opt into it. I know that we had some issues in the past with the cache mechanism when serving functions, with paths that should be updated after a file save but weren't. If this functionality is only available in CJS, can we have a CJS file that's included by the remaining ES codebase? And if that's not an option, will that not be a problem when we load CJS functions defined by users? |
When it comes to mimicking With CommonJS: require('/path/to/example.js') // Cache not used
require('/path/to/example.js') // Cache used
delete require.cache['/path/to/example.js']
require('/path/to/example.js') // Cache not used With pure ES modules (note: this only works if the importing file is using pure ES modules): await import('/path/to/example.js?one') // Cache not used
await import('/path/to/example.js?one') // Cache used
await import('/path/to/example.js?two') // Cache not used Please let me know if my comment is out of topic, as I do not know how caching is currently implemented with functions served locally. |
There's a PR for this issue: #4141 |
@benmccann this PR is only the top of the iceberg. There is a lot of work for the functions resolving to make it compatible. (as some require functionality is used there) |
SvelteKit deploys ESM-only on all platforms except Netlify. The lack of ESM support on Netlify is a continual pain point because SvelteKit and Vite need to bundle to CJS just to support Netlify. Things are more likely to break for Netlify users than users of other platforms since Netlify is the odd-man out in this situation. We currently have a bug caused by where the latest version of SvelteKit is broken for Netlify: sveltejs/kit#6462. I'd really love to see this addressed at some point. FYI @ascorbic - thought you might be interested in this as well since you've contributed to SvelteKit on behalf of Netlify. Thanks again for the help |
Hi @benmccann |
Closed in #6092 |
See background at https://github.com/netlify/team-dev/issues/36
Once #3512 is done and released, we should use pure ES modules and make a major release.
This is more than just switching from CommonJS to
import
/export
. See this list for other changes which might be involved. This should be broken in many PRs, as much as possible, to lower the risk. Also, non-breaking changes (such as adding file extensions in imports, or loading JSON files differently) should be done before the breaking changes (such as usingimport
/export
statements).Since we can make a major release, upgrading would require a user action and no sites would be broken.
The text was updated successfully, but these errors were encountered: