2015-04-28 12:12:31 +08:00
|
|
|
==========
|
|
|
|
JavaScript
|
|
|
|
==========
|
|
|
|
|
|
|
|
While most of Django core is Python, the ``admin`` and ``gis`` contrib apps
|
|
|
|
contain JavaScript code.
|
|
|
|
|
|
|
|
Please follow these coding standards when writing JavaScript code for inclusion
|
|
|
|
in Django.
|
|
|
|
|
|
|
|
Code style
|
2016-01-03 18:56:22 +08:00
|
|
|
==========
|
2015-04-28 12:12:31 +08:00
|
|
|
|
|
|
|
* Please conform to the indentation style dictated in the ``.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.
|
|
|
|
|
|
|
|
* When naming variables, use ``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.
|
|
|
|
|
2020-04-20 16:53:00 +08:00
|
|
|
* Use the `ESLint`_ code linter to check your code for bugs and style errors.
|
|
|
|
ESLint will be run when you run the JavaScript tests. We also recommended
|
|
|
|
installing a ESLint plugin in your text editor.
|
2015-04-28 12:12:31 +08:00
|
|
|
|
2016-03-16 00:11:34 +08:00
|
|
|
* Where possible, write code that will work even if the page structure is later
|
|
|
|
changed with JavaScript. For instance, when binding a click handler, use
|
|
|
|
``$('body').on('click', selector, func)`` instead of
|
|
|
|
``$(selector).click(func)``. This makes it easier for projects to extend
|
|
|
|
Django's default behavior with JavaScript.
|
|
|
|
|
2015-04-28 12:12:31 +08:00
|
|
|
.. _javascript-patches:
|
|
|
|
|
|
|
|
JavaScript patches
|
2016-01-03 18:56:22 +08:00
|
|
|
==================
|
2015-04-28 12:12:31 +08:00
|
|
|
|
|
|
|
Django's admin system leverages the jQuery framework to increase the
|
|
|
|
capabilities of the admin interface. In conjunction, there is an emphasis on
|
|
|
|
admin JavaScript performance and minimizing overall admin media file size.
|
|
|
|
Serving compressed or "minified" versions of JavaScript files is considered
|
|
|
|
best practice in this regard.
|
|
|
|
|
|
|
|
To that end, patches for JavaScript files should include both the original
|
|
|
|
code for future development (e.g. ``foo.js``), and a compressed version for
|
|
|
|
production use (e.g. ``foo.min.js``). Any links to the file in the codebase
|
|
|
|
should point to the compressed version.
|
|
|
|
|
|
|
|
Compressing JavaScript
|
2016-01-03 18:56:22 +08:00
|
|
|
----------------------
|
2015-04-28 12:12:31 +08:00
|
|
|
|
|
|
|
To simplify the process of providing optimized JavaScript code, Django
|
|
|
|
includes a handy Python script which should be used to create a "minified"
|
2015-07-17 05:49:02 +08:00
|
|
|
version. To run it:
|
2015-04-28 12:12:31 +08:00
|
|
|
|
2018-01-21 01:38:48 +08:00
|
|
|
.. console::
|
2015-07-17 05:49:02 +08:00
|
|
|
|
|
|
|
$ python django/contrib/admin/bin/compress.py
|
2015-04-28 12:12:31 +08:00
|
|
|
|
|
|
|
Behind the scenes, ``compress.py`` is a front-end for Google's
|
2015-07-17 05:49:02 +08:00
|
|
|
`Closure Compiler`_ which is written in Java. The Closure Compiler library is
|
2020-04-22 22:19:27 +08:00
|
|
|
not bundled with Django, but will be installed automatically by ``npm``. The
|
2015-07-17 05:49:02 +08:00
|
|
|
Closure Compiler library requires `Java`_ 7 or higher.
|
2015-04-28 12:12:31 +08:00
|
|
|
|
|
|
|
Please don't forget to run ``compress.py`` and include the ``diff`` of the
|
|
|
|
minified scripts when submitting patches for Django's JavaScript.
|
|
|
|
|
2016-06-20 05:08:41 +08:00
|
|
|
.. _javascript-tests:
|
|
|
|
|
2015-04-14 22:55:57 +08:00
|
|
|
JavaScript tests
|
2016-01-03 18:56:22 +08:00
|
|
|
================
|
2015-04-14 22:55:57 +08:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
Writing tests
|
2016-01-03 18:56:22 +08:00
|
|
|
-------------
|
2015-04-14 22:55:57 +08:00
|
|
|
|
|
|
|
Django's JavaScript tests use `QUnit`_. Here is an example test module:
|
|
|
|
|
|
|
|
.. code-block:: javascript
|
|
|
|
|
2017-12-19 03:49:00 +08:00
|
|
|
QUnit.module('magicTricks', {
|
2015-04-14 22:55:57 +08:00
|
|
|
beforeEach: function() {
|
|
|
|
var $ = django.jQuery;
|
|
|
|
$('#qunit-fixture').append('<button class="button"></button>');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2017-12-19 03:49:00 +08:00
|
|
|
QUnit.test('removeOnClick removes button on click', function(assert) {
|
2015-04-14 22:55:57 +08:00
|
|
|
var $ = django.jQuery;
|
|
|
|
removeOnClick('.button');
|
2017-12-19 03:49:00 +08:00
|
|
|
assert.equal($('.button').length, 1);
|
2015-04-14 22:55:57 +08:00
|
|
|
$('.button').click();
|
2017-12-19 03:49:00 +08:00
|
|
|
assert.equal($('.button').length, 0);
|
2015-04-14 22:55:57 +08:00
|
|
|
});
|
|
|
|
|
2017-12-19 03:49:00 +08:00
|
|
|
QUnit.test('copyOnClick adds button on click', function(assert) {
|
2015-04-14 22:55:57 +08:00
|
|
|
var $ = django.jQuery;
|
|
|
|
copyOnClick('.button');
|
2017-12-19 03:49:00 +08:00
|
|
|
assert.equal($('.button').length, 1);
|
2015-04-14 22:55:57 +08:00
|
|
|
$('.button').click();
|
2017-12-19 03:49:00 +08:00
|
|
|
assert.equal($('.button').length, 2);
|
2015-04-14 22:55:57 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
Please consult the QUnit documentation for information on the types of
|
2017-05-03 19:31:59 +08:00
|
|
|
`assertions supported by QUnit <https://api.qunitjs.com/assert/>`_.
|
2015-04-14 22:55:57 +08:00
|
|
|
|
|
|
|
Running tests
|
2016-01-03 18:56:22 +08:00
|
|
|
-------------
|
2015-04-14 22:55:57 +08:00
|
|
|
|
|
|
|
The JavaScript tests may be run from a web browser or from the command line.
|
|
|
|
|
|
|
|
Testing from a web browser
|
2016-01-03 18:56:22 +08:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2015-04-14 22:55:57 +08:00
|
|
|
|
|
|
|
To run the tests from a web browser, open up ``js_tests/tests.html`` in your
|
|
|
|
browser.
|
|
|
|
|
|
|
|
To measure code coverage when running the tests, you need to view that file
|
|
|
|
over HTTP. To view code coverage:
|
|
|
|
|
2017-01-19 00:51:29 +08:00
|
|
|
* Execute ``python -m http.server`` from the root directory (not from inside
|
|
|
|
``js_tests``).
|
2015-04-14 22:55:57 +08:00
|
|
|
* Open http://localhost:8000/js_tests/tests.html in your web browser.
|
|
|
|
|
|
|
|
Testing from the command line
|
2016-01-03 18:56:22 +08:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2015-04-14 22:55:57 +08:00
|
|
|
|
|
|
|
To run the tests from the command line, you need to have `Node.js`_ installed.
|
|
|
|
|
2020-03-31 16:37:38 +08:00
|
|
|
After installing ``Node.js``, install the JavaScript test dependencies by
|
|
|
|
running the following from the root of your Django checkout:
|
2015-04-14 22:55:57 +08:00
|
|
|
|
2018-01-21 01:38:48 +08:00
|
|
|
.. console::
|
2015-04-14 22:55:57 +08:00
|
|
|
|
|
|
|
$ npm install
|
|
|
|
|
|
|
|
Then run the tests with:
|
|
|
|
|
2018-01-21 01:38:48 +08:00
|
|
|
.. console::
|
2015-04-14 22:55:57 +08:00
|
|
|
|
|
|
|
$ npm test
|
|
|
|
|
2015-04-28 12:12:31 +08:00
|
|
|
.. _Closure Compiler: https://developers.google.com/closure/compiler/
|
2018-09-26 14:48:47 +08:00
|
|
|
.. _EditorConfig: https://editorconfig.org/
|
2015-04-28 12:12:31 +08:00
|
|
|
.. _Java: https://www.java.com
|
2020-04-20 16:53:00 +08:00
|
|
|
.. _eslint: https://eslint.org/
|
2015-04-14 22:55:57 +08:00
|
|
|
.. _node.js: https://nodejs.org/
|
|
|
|
.. _qunit: https://qunitjs.com/
|