data:image/s3,"s3://crabby-images/c5e1e/c5e1e7735b66ef960e8000f0bf85782c88fc478f" alt=""
data:image/s3,"s3://crabby-images/f1140/f1140dd72278b673b8a82708669750ba243e0249" alt=""
data:image/s3,"s3://crabby-images/8ee77/8ee77c9c476c3db45fa3b829e4bf1c7c3708432a" alt=""
data:image/s3,"s3://crabby-images/492db/492db62c6df908350d8ceda27a93347ab39c0379" alt=""
data:image/s3,"s3://crabby-images/c4dec/c4dec67d69b5658d91668d1ab2e8fc54c8d2f406" alt=""
Snowpack is the fastest and easiest way ever to benefit from npm and imports in frontend code without going full SPA.
Elected Productivity Booster OS Award 2020, Snowpack is a frontend builder with a startup time of 50ms, which typically can be 30s in a typical Webpack project.
Changing a frontend file will typically not cause a Django view reload because Django doesn’t want to provide JS by default: djsnowpack provides a solution for that.
# go and make a virtualenv in /tmp
cd /tmp
virtualenv /tmp/djsnowpack_demo
source /tmp/djsnowpack_demo/bin/activate
# clone and install the app and example project
git clone https://yourlabs.io/oss/djsnowpack
cd djsnowpack
pip install .
# install example project dependencies and start server
cd djsnowpack_example
pip install django
yarn install
./manage.py runserver
pip install djsnowpack
,settings.MIDDLEWARE
: djsnowpack.Middleware
,settings.STATICFILES_DIRS
: os.path.join(BASE_DIR, 'build')
.This allows you to have a Snowpack frontend project inside your
settings.BASE_DIR
.
You should see a minimal example in djsnowpack_example
directory:
package.json
: get one from a template
project,
minimal one is good to just get going without any specific framework or libraryindex.html
: snowpack needs it to work so you’ll just put it there once and
then forget about itindex.js
: this is the entrypoint that will be served by snowpackindex.css
: same but optional and for styles, sass works well with
snowpack tooDANGER: you MUST have the following in your index.html to make Django view reload on JS change:
if (import.meta.hot) {
import.meta.hot.accept(({ module }) => {
import.meta.hot.invalidate();
});
}
index.html content:
<!DOCTYPE html>
<html lang="en">
<head>
<link rel="stylesheet" type="text/css" href="/index.css" />
</head>
<body>
<script type="module" src="/index.js"></script>
</body>
</html>
Remove index.css if you just don’t need it.
Have fun hacking frontend faster than ever !