djlint-vscode
Visual Studio Code extension for formatting and linting HTML templates (Django, Jinja, Nunjucks, Twig, Handlebars, Mustache) using djLint.
Installation
- Install djLint itself with the
python -m pip install -U djlint
command. - Install djLint VS Code extension from Visual Studio Marketplace or Open VSX.
Usage
If you have the Python extension installed, djlint-vscode
will use the djLint
installed in the currently activated Python environment, unless you have the djlint.useVenv
extension setting disabled.
The extension can be configured through the settings in VS Code. Some options can be configured through the djLint configuration file.
Add this to your settings.json
to format the default enabled languages with djLint
:
"[html][django-html][handlebars][hbs][mustache][jinja][jinja-html][nj][njk][nunjucks][twig]": {
"editor.defaultFormatter": "monosans.djlint"
}
Usage with djLint installed with pipx
pipx creates a separate venv for each application. You can see where it creates the venv with the pipx environment --value PIPX_LOCAL_VENVS
command. For me it is /home/user/.local/pipx/venvs
. This way I can set these settings:
"djlint.useVenv": false,
"djlint.pythonPath": "/home/user/.local/pipx/venvs/djlint/bin/python",
Known issues
-
Non-ASCII characters turn into
?
on Windows after formatting. To fix this, updatedjLint
to v1.1.1 or higher. -
Linting does not work on Windows if the file contains non-ASCII characters. To fix this, update
djLint
to v1.1.1 or higher. -
File contents are duplicated after formatting. This is a bug in
djLint
v1.12.1, install another version. -
The config file is ignored on some versions of Python if it is in the root of the project. To fix this, update
djLint
to v1.19.2 or higher.