自己并未采用任何表格插件,参考网上例子,自己编写出来的django网页实例,请各位参考!

首先看图做事,表格布局采用bootstrap,俗话说bootstrap橹多了就会css了,呵呵,下面看图:

上面有两个按钮,是动态添加进来的,可以使用jquery语言,$("#xx").append新添一个按钮,

最基本的表单代码:

<button class="btn btn-small btn-primary" type="button" id="blank">添加空白表单</button>
<form class="form-inline">
{% csrf_token %}
<table class="table table-conde" id="t2">
<caption class="text-left"></caption>
<thead></thead>
<tbody></tbody>
<tfoot></tfoot>
</table>
<table class="table table-conde" id="t3">
<caption class="text-left"></caption>
<thead></thead>
<tbody></tbody>
<tfoot></tfoot>
</table>
<div class="text-center" id="form_add"></div>
</form>

接下来使用js动态加载表格:

$('#blank').click(function(){//空白表单
$("#t1 caption").append("<span class='text-info'><i class='icon-forward'></i> 合同基础清单</span>");
$("#t1 tbody").append(formbill());
$("#t2 caption").append("<span class='text-info'><i class='icon-forward'></i> 附件1 合同手机清单 &nbsp;&nbsp;&nbsp;&nbsp;<a class='btn btn-small' id='t2row'><i class='icon-plus'></i> 添加一行</a></span>");
$("#t2 thead").append("<th>客户姓名</th><th>合同号</th><th>业务号码</th><th>套餐类型</th><th>经办人</th><th>备注</th><th>操作</th>");
$("#t3 caption").append("<span class='text-info'><i class='icon-forward'></i> 附件2 合同座机清单 &nbsp;&nbsp;&nbsp;&nbsp;<a class='btn btn-small' id='t3row'><i class='icon-plus'></i> 添加一行</a></span>");
$("#t3 thead").append("<th>客户姓名</th><th>合同号</th><th>业务号码</th><th>套餐类型</th><th>经办人</th><th>备注</th><th>操作</th>");
$("#form_add").append("<input type='button' id='btn_add' value='提交数据' class='btn btn-primary btn-sm'/>");
});

然后实现行添加和行删除的功能:

//行添加
$('#t2 caption').on("click","#t2row",function(){
var len = $("#t2 tr").length+1;
$("#t2 tbody").append("<tr id="+len+">"
+"<td><input type='text' class='input-medium acct_code' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium acc_nbr' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium tc_type' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium con_agent' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium remark' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium remark' placeholder='.input-medium'></td>"
+"<td><a class='btn btn-small' onclick='deltr("+len+")'>删除</a></td>"
+"</tr>"
);
});
$('#t3 caption').on("click","#t3row",function(){
var len = $("#t3 tr").length+1;
$("#t3 tbody").append("<tr id="+len+">"
+"<td><input type='text' class='input-medium acct_name' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium acct_code' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium acc_nbr' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium tc_type' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium con_agent' placeholder='.input-medium'></td>"
+"<td><input type='text' class='input-medium remark' placeholder='.input-medium'></td>"
+"<td><a class='btn btn-small' onclick='deltr("+len+")'>删除</a></td>"
+"</tr>"
);
});
//行删除
   function deltr(index) {
     $("tr[id='"+index+"']").remove();//删除当前行
    }

这里要注意两个问题:

第一,像id=t2row/t3rowde 按钮是动态添加上的,如果使用普通的$('#xxx').click是没用的,必须使用$('#t2 caption').on("click","#t2row",function(){})这种格式

第二,删除按钮的id必须跟tr中的id相对应

实现行添加和行删除的功能后,该考虑如何将多字段的表单传递到django的后端中去,代码如下:

          var str_tailsj = "[";
$("#t2 tbody").find("tr").each(function(){
var tdArr1 = $(this).children();
str_tailsj = str_tailsj+"{'product_name':'手机',";
str_tailsj = str_tailsj+"'acct_name':'"+ tdArr1.eq(0).find("input").val()+"',";
str_tailsj = str_tailsj+"'acct_code':'"+ tdArr1.eq(1).find("input").val()+"',";
str_tailsj = str_tailsj+"'acc_nbr':'"+ tdArr1.eq(2).find("input").val()+"',";
str_tailsj = str_tailsj+"'tc_type':'"+ tdArr1.eq(3).find("input").val()+"',";
str_tailsj = str_tailsj+"'con_agent':'"+ tdArr1.eq(4).find("input").val()+"',";
str_tailsj = str_tailsj+"'remark':'"+ tdArr1.eq(5).find("input").val()+"'},";
});
str_tailsj = str_tailsj + "]";

将多字段表单,用json字符串的形式传递到后端,然后在后端利用python中的eval转换成相应的形式进行处理,具体代码参照下:

参照网址:http://www.cnblogs.com/CQ-LQJ/p/5442785.html

a="[{'bill1':'1','bill41':'2'},{'bill1':'1','bill41':'2'},]"
print eval(a)[0]['bill1']
输出为1

[django]表格的添加与删除实例(可以借鉴参考)的更多相关文章

  1. js动态添加-表格逐行添加、删除、遍历取值

    关于js对表格进行逐行添加,今天抽空整理了一下:新建一个html文件(没有编辑器的可以新建一个demo.txt文件,然后改后缀名为demo.html),把下面代码全部贴进去即可.功能包括:表格添加一行 ...

  2. yii gii自动生成的curd添加批量删除实例

    1.在视图中 CGridView中的columns添加,作用是添加多选框  代码如下 复制代码 array(        'selectableRows' => 2,        'foot ...

  3. javascript表格的添加和删除

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  4. 利用jquery动态添加和删除表格的一行,并且保存单行数据

    开发时遇到一个需求:要求要在页面的表格可以添加和删除一行,并能填写对应的数据后保存这一行数据. HTML代码 界面使用了freemarker框架,teams是后台传过来的list类型数据 <fo ...

  5. 添加,删除List<Map<String, Object>>元素

    这里讲对List<Map<String, Object>>的数据结构的添加和删除实例 添加 //初始化 List<Map<String, Object>> ...

  6. Django实现简单的用户添加、删除、修改等功能

    一. Django必要的知识点补充 1. templates和static文件夹及其配置 1.1 templates文件夹 所有的HTML文件默认都放在templates文件夹下. 1.2 stati ...

  7. Javascript DOM 03 表格添加、删除 + 搜索

    获取 tBodies.tHead.tFoot.rows.cells   隔行变色 鼠标移入高亮   添加.删除一行 DOM方法的使用                                   ...

  8. JS添加或删除HTML dom元素的方法实例分析

    本文实例讲述了JS代码添加或删除HTML dom元素的方法.分享给大家供大家参考,具体如下: 创建新的 HTML 元素 如需向 HTML DOM 添加新元素,您必须首先创建该元素(元素节点),然后向一 ...

  9. swift - 表格的编辑功能(添加、删除)

    表格(tableview)的确是一个很好用的控件,现在来实现一个编辑功能的实现,包含添加和删除,删除包括长按删除和左滑删除 效果图如下: 具体代码如下: 1.创建表格(这个表格有2个区,有区头和区尾) ...

随机推荐

  1. 【笔记】Asp.Net WebApi对js POST带参数跨域请求的支持方案

    先说下需求:在原来的WebApi项目中增加对js跨域的请求支持,请求方式:以POST为主,webapi路由规则根据原项目需求修改如下: public static void Register(Http ...

  2. php中用GD绘制折线图

    php中用GD绘制折线图,代码如下: Class Chart{ private $image; // 定义图像 private $title; // 定义标题 private $ydata; // 定 ...

  3. 采花 bzoj 2743

    采花(1s 128MB)flower [题目描述] 萧芸斓是Z国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了n朵花,花有c种颜色(用整 ...

  4. css判断不同分辨率显示不同宽度布局实现自适应宽度

    一.CSS DIV网页布局中当分辨率小于等于1024px(像素)时,DIV布局对象显示1000px宽度,当分辨率大于1024px时候显示1200px宽度等需求.使用CSS实现改变浏览器显示宽度从而实现 ...

  5. maven:用appassembler-maven-plugin打包含有自定义目录的JAVA程序

    问题说明: 用maven构建了一个项目,目录结构如下: appassemblerd的配置: <plugin> <groupId>org.codehaus.mojo</gr ...

  6. 【超全整理】J2EE集成开发环境MyEclipse使用心得汇总

    一.首先我们为什么需要MyEclipse? 下面允许我做一些简要的介绍: 应该大家都知道另一个MyEclipse的近亲——Eclipse的优点:免费.程序代码排版功能.有中文汉化包.可增设许多功能强大 ...

  7. 安装Portal for ArcGIS时如何正确配置HTTPS证书

    SSL协议位于TCP/IP协议与各种应用层协议之间,为数据通讯提供安全支持.SSL协议可分为两层: SSL记录协议(SSL Record Protocol):它建立在可靠的传输协议(如TCP)之上,为 ...

  8. asp.netDataTable导出excel方法(2)

    上一篇文章提到看到同事导出excel的新方法,感觉比上一篇简单得多,所以想贴上来,与大家分享. 在后台拼数据,都是用的htmltable标签的写法: string line = "text- ...

  9. 生成的API分析文件太大。我们无法在交付前验证您的API使用信息。这只是通知信息。

    这次使用了APICloud平台来开发移动APP, 发布的时候在api控制台云编译成ipa后,这次使用apple提供的Application Loader工具提交apa文件到iTunes上去,提交结束的 ...

  10. Android Support Library介绍

    v4 Support Library 这个库是为Android 1.6(API版本为4)及以上的版本设计的,它包含大部分高版本中有而低版本中没有的API,包括application component ...