While most of Django core is Python, the admin
and gis
contrib apps
contain JavaScript code.
在编写用于包含在 Django 中的 JavaScript 代码时,请遵循以下编码标准:
.editorconfig
file. We recommend using a text editor with EditorConfig support to avoid
indentation and whitespace issues. Most of the JavaScript files use 4 spaces
for indentation, but there are some exceptions.camelCase
instead of underscore_case
.
Different JavaScript files sometimes use a different code style. Please try to
conform to the code style of each file.$('body').on('click', selector, func)
instead of
$(selector).click(func)
. This makes it easier for projects to extend
Django's default behavior with JavaScript.Django 的管理系统利用 jQuery 框架来增强管理界面的功能。同时,强调管理 JavaScript 的性能和尽量减少整体管理媒体文件的大小。
Django's JavaScript tests can be run in a browser or from the command line. The tests are located in a top level js_tests directory.
Django's JavaScript tests use QUnit. Here is an example test module:
QUnit.module('magicTricks', {
beforeEach: function() {
const $ = django.jQuery;
$('#qunit-fixture').append('<button class="button"></button>');
}
});
QUnit.test('removeOnClick removes button on click', function(assert) {
const $ = django.jQuery;
removeOnClick('.button');
assert.equal($('.button').length, 1);
$('.button').click();
assert.equal($('.button').length, 0);
});
QUnit.test('copyOnClick adds button on click', function(assert) {
const $ = django.jQuery;
copyOnClick('.button');
assert.equal($('.button').length, 1);
$('.button').click();
assert.equal($('.button').length, 2);
});
Please consult the QUnit
documentation for information on the types of
assertions supported by QUnit.
JavaScript 测试可以在网页浏览器或命令行中运行。
To run the tests from a web browser, open up js_tests/tests.html in your browser.
在运行测试时测量代码覆盖率,您需要通过 HTTP 查看该文件。要查看代码覆盖率:
python -m http.server
from the root directory (not from inside
js_tests
).9月 22, 2023