首先,您应该为您的网址:
url(r'^blog/(?P<item_id>\d+)/$', 'blog.ajax.remove_item', name='blog-item'),
然后,你可以通过网址作为变量的模块:
<script src="{{ STATIC_URL }}js/my-module.js"></script>
<script>
$(function(){
MyModule.init('{% url blog-item item.id %}');
});
</script>
// js/my-module.js
var MyModule = {
init: function(url) {
console.log(url);
}
};
你可以在你的URL中使用的令牌:
<script src="{{ STATIC_URL }}js/my-module.js"></script>
<script>
$(function(){
MyModule.init("{% url blog-item item_id='0000' %}");
});
</script>
// js/my-module.js
var MyModule = {
init: function(url) {
var id = 1;
this._url = url;
console.log(this.url(id));
},
url: function(id) {
return this._url.replace('0000', id);
}
};
请注意,您的令牌应该与正则表达式类型匹配才能成功解析(我不能使用{item_id}
作为标记,因为它的定义为\d+
)。
我对这个解决方案有点不满意,最后我写了自己的应用程序来处理javascript与Django:django.js。有了这个应用程序,我可以这样做:
{% load js %}
{% django_js %}
{% js "js/my-module.js" %}
// js/my-module.js
var MyModule = {
init: function() {
var id = 1;
console.log(Django.url('blog-item', id));
}
};
$(function(){
MyModule.init();
});
也检查出一些叉子。 Dimitri-Gnidash使用管理命令构建URL。 ljosa创建了一个视图,在飞行中建立它们。 – SystemParadox 2012-02-08 15:33:55
看来这个解决方案仍然需要硬编码{url_name:pattern}字典。自动生成在dutils.conf.urls.example.js中找到的列表会很好。 – Fydo 2013-09-05 13:57:31
@Fydo使用它https://github.com/ierror/django-js-reverse – 2017-05-12 15:19:49