7đź‘Ť
If you’ve got an element in your template which you’re getting to then detect clicks, why not just do it the other way around where you can then pass the context variable to your JS function?
<button onclick="create_table({{ row_data }})">Click me</button>
By doing that you can inspect the page to see if the data is going to be passed correctly. You’ll probably have to pass the data through a filter like escapejs
or safe
.
Alternatively you could do something like
{% load static %}
<button id="create_table">Get data</button>
<div id="place_for_table"></div></div>
<script type="text/javascript">
var row_data = "{{ row_data }}";
</script>
<script src="{% static 'javascript/scripts/create_table.js' %}">
</script>
The issue with this approach is the scope of variables as you may not want to declare things globally so it could be considered an easy approach, but not necessarily the best solution.
5đź‘Ť
When you write {{ row_data }}
, you’re using a Django-specific “language” called Django template language which means that the mentioned syntax can only be “understood” by Django templates.
What you’re doing here is loading a separate JavaScript file in which the Django template syntax simply won’t work because when browser comes to the point to evaluate that file, {{ row_data }}
will look just another string literal, and not what you would expect to.
It should work if you inline your JavaScript example directly into the Django template.
Alternatively you could somehow “bootstrap” the external JavaScript file with the data available in the Django template, here’s how I would go about doing that:
create_table.html
<script src="{% static 'javascript/scripts/create_table.js' %}"></script>
<script type="text/javascript">
$(function() {
var create_table = Object.create(create_table_module);
create_table.init({
row_data: '{{ row_data }}',
...
});
});
</script>
Note: wrapping the above code in the jQuery’s .ready() function is optional, but if you’re already using jQuery in your app, it’s a simple way to make sure the DOM is safe to manipulate after the initial page load.
create_table.js
var create_table_module = (function($) {
var Module = {
init: function(opts) {
// you have access to the object passed
// to the `init` function from Django template
console.log(opts.row_data)
},
};
return Module;
})(jQuery);
Note: passing jQuery instance to the module is optional, it’s just here as an example to show how you can pass an external dependancy to the module.
- Upgrading to Django 1.7. Getting error: Cannot serialize: <storages.backends.s3boto.S3BotoStorage object
- Is it a good practice to use serializer as query parameters validators?
- How to check whether user is logged in or not
- Celery + Django: Cannot start celerybeat on Windows 7
3đź‘Ť
What I did was to include the javascript/jquery inside
{% block scripts %}
and use the the Django specific data as follows:
`
$.ajax({
type:"GET",
url: "/reserve/run/?ip={{ row_data }}",
dataType: "html",
async: true,
}).done(function(response) {
$("#Progress").hide();
$('#clickid').attr('href','javascript:ClearFlag()');
var win = window.open("", "MsgWindow");
win.document.write(response);
});
`
- Django templates stripping spaces?
- Django + uWSGI + Nginx + SSL – request for working configuration (emphasis on SSL)
- Make django templates strict
- Django – Multiple apps on one webpage?
3đź‘Ť
I’ve found a solution to avoid the extra typing of all the previous answers.
It’s a bit hacky:
Just transform you myjavascriptfile.js
into myjavascriptfile.js.html
and wrap the code in a <script>...</script>
tag. Than include
them instead of linking them in your template file.
myTemplate.html
....
{% block js_footer %}
{% include "my_app/myjavascriptfile.js.html" %}
{% endblock js_footer %}
myjavascriptfile.js.html
<script type="text/javascript">
console.log('the time now is {% now "Y m d H:i:s" %}');
...
</script>
- Improving Performance of Django ForeignKey Fields in Admin
- How to set "simple" password in Django 1.9
- Django: duplicates when filtering on many to many field
- Provide tab title with reportlab generated pdf
0đź‘Ť
instead of writing the function in a separated js file, write it in script tags within your html page, so it can use the django template language
- Django extract string from [ErrorDetail(string='Test Message', code='invalid')]
- Django or web.py, which is better to build a large website with Python?
- Error loading MySQLdb module: libmysqlclient.so.20: cannot open shared object file: No such file or directory
0đź‘Ť
You can use Django template tags and filters in <script></script>
.
For example, you can pass Hello
to with tag’s dj_val
and upper filter in <script></script>
in index.html
, then Hello
and HELLO
was displayed on console as shown below:
{% "index.html" %}
<script>
{% with dj_val="Hello" %}
console.log("{{ dj_val }}") # Hello
{% endwith %}
console.log("{{ "Hello"|upper }}") # HELLO
</script>
Be careful, you cannot pass JavaScript’s js_val
set Hello
to with
tag’s dj_val
and upper
filter in <script></script>
in index.html
, then nothing was displayed on console as shown below:
{% "index.html" %}
<script>
let js_val = "Hello"
{% with dj_val=js_val %}
console.log("{{ dj_val }}") # Nothing
{% endwith %}
console.log("{{ js_val|upper }}") # Nothing
</script>
- How do you update a django template context variable after an AJAX call?
- Using Node.js with Django and Backbone.js