为Django中的引导表重用javascript函数
Reuse javascript function for bootstrap tables in Django
我想通过javascript创建4个结构相同但内容不同的引导表。每个表的数据已经是json格式了。
我迭代django模板中的表数据jsons列表(列表中的每个元素都代表一个制造商):
{% for helis in helis_by_mnfcr %}
{% if helis %}
<table id="table_{{ helis.0.mnfcr.split|join:"_" }}" data-sort-name="score" data-sort-order="desc">
</table>
{% endif %}
{% endfor %}
然后我在script
块中有一个javascript函数,看起来像这样:
data_boeing = {{ helis_by_mnfcr.0|safe }}
$(function () {
$(#table_boeing).bootstrapTable({
data: data_boeing,
striped: true,
pagination: true,
pageSize: 4,
pageList: [4, 10, 25],
search: true,
showColumns: true,
showRefresh: true,
minimumCountColumns: 2,
clickToSelect: true,
columns: [
{
field: 'name',
title: 'Name',
valign: 'middle',
width: '75%',
formatter: NameFormatter,
events: operateEvents
}, {
field: 't',
title: 'Deployed',
align: 'center',
valign: 'middle',
width: '15%',
sortable: true
}]
});
});
正如预期的那样,这只适用于一家制造商(在这种情况下为"波音")。我可以做些什么来为所有制造商修改和重用此功能?
只需将模板逻辑重用到javascript即可。如果我没记错的话是这样的:
$(function () {
{% for helis in helis_by_mnfcr %}
{% if helis %}
{% with id=helis_by_mnfcr.mnfcr.split|join:"_" %}
var table_id = '#table_{{ id }}';
$(table_id).bootstrapTable({
data: data_{{ id }},
striped: true,
pagination: true,
// ... Other attrs ommited
});
{% endwith %}
{% endif %}
{% endfor %}
});
因此,上面将创建具有正确id和数据的N引导表(通过for循环)。
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 正在全局范围中查找JavaScript函数
- 如何将输入(type=text)从html表单传递到javascript函数
- 如何调用这个匿名 JavaScript 函数
- 通过Ajax将JavaScript函数传递给PHP文件
- 在javascript函数中设置全局变量
- 如何在执行此特定onclick事件时执行JavaScript函数
- 使用javascript函数在页面初始化后加载jquery
- javascript函数同步
- 如何将一个JavaScript函数回调为多个函数
- 在javascript函数中使用php变量
- 代码背后调用一个JavaScript函数的按钮点击-C#
- 将JavaScript函数与HTML分离
- 组合两个javascript函数
- 在 Java 中的 JavaScript 函数中插入 Wicket 值
- javascript函数内部的代码用逗号而不是分号分隔
- href属性内的javascript函数
- 使用html表单中的参数调用JavaScript函数
- 分析Javascript函数中的多个对象
- javascript函数的:和=之间的区别