Preservation of local component state after JS updates is disabled to avoid unpredictable and error-prone behavior. You can read more about it here.
Please note that if you only edit the <style>
node, a separate CSS update can be applied where component state is 100% preserved.
The <style>
node should be last to ensure optimal HMR results. This is also the default order with prettier-plugin-svelte.
Good:
<script></script>
<div></div>
<style></style>
Bad:
<script></script>
<style></style>
<!-- this template element is below the style node and may cause extra HMR updates -->
<div></div>
You have to use the lang="ts"
attribute for Vite to parse it. Never lang="typescript"
or type="text/typescript"
.
Good:
<script lang="ts"></script>
Bad:
<!-- These are not detected by Vite -->
<script lang="typescript"></script>
<script type="text/typescript"></script>
Global styles should always be placed in their own stylesheet files whenever possible, and not in a Svelte component's <style>
tag. The stylesheet files can then be imported directly in JS and take advantage of Vite's own style processing. It would also significantly improve the dev server startup time.
Good:
/* global.scss */
html {
color: $text-color;
}
// main.js
import './global.scss';
Bad:
<style lang="scss">
:global(html) {
color: $text-color;
}
</style>
If you are building a Vite plugin that transforms CSS or JS, you can add a api.sveltePreprocess: PreprocessorGroup
to your Vite plugin definition and it will be added to the list of Svelte preprocessors used at runtime.
const vitePluginCoolCss = {
name: 'vite-plugin-coolcss',
api: {
sveltePreprocess: {
/* your PreprocessorGroup here */
}
}
/*... your cool css plugin implementation here .. */
};
For reference, check out windicss.
Pre-bundling dependencies is an optimization in Vite. It is required for CJS dependencies, as Vite's development server only works with ES modules on the client side.
Historically, Svelte components had issues being pre-bundled, causing deduplication issues and CJS interoperability issues. Since Vite 2.5.2, a new API in Vite allowed us to automatically handle Svelte library pre-bundling for you.
This feature had served us well, however a caveat remained that large Svelte component libraries often slows down the initial page load. If this affects you, try setting experimental.prebundleSvelteLibraries option to true
to speed things up. (Note that it's an experimental option)
In case you still run into errors like The requested module 'xxx' does not provide an export named 'yyy'
, please check our open issues.