.github | ||
elements | ||
scripts | ||
site/content | ||
src | ||
test | ||
.editorconfig | ||
.eslintignore | ||
.eslintrc.cjs | ||
.gitattributes | ||
.gitignore | ||
.prettierignore | ||
.prettierrc | ||
CHANGELOG.md | ||
check_publish_env.js | ||
CODE_OF_CONDUCT.md | ||
codemod-lazy-props.mjs | ||
CONTRIBUTING.md | ||
generate-types.mjs | ||
LICENSE.md | ||
package.json | ||
pnpm-lock.yaml | ||
README.md | ||
register.js | ||
rollup.config.mjs | ||
tsconfig.json | ||
vitest.config.js |
What is Svelte?
Svelte is a new way to build web applications. It's a compiler that takes your declarative components and converts them into efficient JavaScript that surgically updates the DOM.
Learn more at the Svelte website, or stop by the Discord chatroom.
Supporting Svelte
Svelte is an MIT-licensed open source project with its ongoing development made possible entirely by fantastic volunteers. If you'd like to support their efforts, please consider:
Funds donated via Open Collective will be used for compensating expenses related to Svelte's development such as hosting costs. If sufficient donations are received, funds may also be used to support Svelte's development more directly.
Roadmap
You may view our roadmap if you'd like to see what we're currently working on.
Development
Pull requests are encouraged and always welcome. Pick an issue and help us out!
To install and work on Svelte locally:
git clone https://github.com/sveltejs/svelte.git
cd svelte
pnpm install
Do not use Yarn to install the dependencies, as the specific package versions in
package-lock.json
are used to build and test Svelte.
To build the compiler and all the other modules included in the package:
pnpm build
To watch for changes and continually rebuild the package (this is useful if you're using pnpm link
to test out changes in a project locally):
pnpm dev
The compiler is written in TypeScript, but don't let that put you off — it's basically just JavaScript with type annotations. You'll pick it up in no time. If you're using an editor other than Visual Studio Code, you may need to install a plugin in order to get syntax highlighting and code hints, etc.
Running Tests
pnpm test
To filter tests, use -g
(aka --grep
). For example, to only run tests involving transitions:
pnpm test -- -g transition
svelte.dev
The source code for https://svelte.dev lives in the sites repository, with all the documentation in the site/content directory. The site is built with SvelteKit.
Is svelte.dev down?
Probably not, but it's possible. If you can't seem to access any .dev
sites, check out this SuperUser question and answer.