在Bootstrap开发框架中使用dataTable直接录入表格行数据的方法


Posted in Javascript onOctober 25, 2018

在Winform开发的时候,我们很多时候可以利用表格控件来直接录入数据,不过在Web上较少看到,其实也可以利用dataTable对象处理直接录入表格行数据,这个可以提高数据的录入方便,特别是在一些简单业务的明细数据的时候,看起来会比弹出窗口录入方便一些,也高大上一点。本篇主要介绍在Bootstrap开发框架中使用dataTable直接录入表格行数据。

1、基于表格直接录入数据和Winform的界面回顾

在开始Web界面直接录入表格行数据前,我们先来看看Winform界面的处理情况,如我在流程管理里面,对于具有主从明细的报销业务表的数据处理,采用了下面的界面。

在Bootstrap开发框架中使用dataTable直接录入表格行数据的方法

这种明细表单可以直接在表格控件Griview上进行新增、编辑处理。

而对于Web界面,如果我们要保持和这个布局类似的话,采用dataTable直接录入表格行数据也可以达到。

在Bootstrap开发框架中使用dataTable直接录入表格行数据的方法

上面的界面处理明细数据的时候,可以直接使用新增记录,直接在录入框中输入数据,然后保存起来,保存后数据变为只读,如果需要修改,还可以单击编辑按钮进行修改。

而这些明细的数据,也仅仅存在JS的对象里面,还没有保存到后台数据库中,我们可以在最后保存(如上界面的确定按钮)处理中再获取全部添加的数据进行提交即可。

在这些数据提交之后,我们在查看界面里面可以可以Bootstrap Table插件来展示数据即可。

在Bootstrap开发框架中使用dataTable直接录入表格行数据的方法

2、在Web上使用dataTable直接录入表格行数据的实现

上面的界面展示了在Web上使用dataTable直接录入表格行数据和数据展示,这里开始介绍它们的界面和实现代码。

界面部分主要是这个明细的处理。

在Bootstrap开发框架中使用dataTable直接录入表格行数据的方法

界面视图的HTML代码如下所示。

<div class="portlet light portlet-fit ">
  <div class="portlet-title">
    <div class="caption">
      <i class="icon-settings font-red"></i>
      <span class="caption-subject font-red sbold uppercase">明细清单</span>
    </div>
  </div>
  <div class="portlet-body">
    <div class="table-toolbar">
      <div class="row">
        <div class="col-md-6">
          <div class="btn-group">
            <button id="detail_editable_1_new" class="btn green">
              新增记录
              <i class="fa fa-plus"></i>
            </button>
          </div>
        </div>
      </div>
    </div>
    <table class="table table-striped table-hover table-bordered" id="detail_editable_1">
      <thead>
        <tr>     
          <th>序号</th>
          <th> 费用类型 </th>
          <th> 发生时间 </th>
          <th> 费用金额(元) </th>
          <th> 费用说明 </th>
          <th> 编辑 </th>
          <th> 删除 </th>
        </tr>
      </thead>
      <tbody>
        @*<tr>
          <td> 1 </td>
          <td> 交通费 </td>
          <td> 2018-10-01 </td>
          <td> 2000 </td>
          <td> 备注信息 </td>
          <td>
            <a class="edit" href="javascript:;" rel="external nofollow" rel="external nofollow" > 编辑 </a>
          </td>
          <td>
            <a class="delete" href="javascript:;" rel="external nofollow" rel="external nofollow" > 删除 </a>
          </td>
        </tr>*@
      </tbody>
    </table>
  </div>
</div>

其中主要是ID为 detail_editable_1 的标记,这个就是承载明细信息的表格,我们可以定义我们需要的表头信息,而输入框的内容,则可以通过dataTable插件的对象进行动态添加。

//定义dataTable对象
      var table = $('#detail_editable_1');
      var oTable = table.dataTable({
        "lengthMenu": [
          [5, 15, 20, -1],
          [5, 15, 20, "All"] // 改变每页的行数
        ],

        // 使用汉化
        "language": {
          url: '//cdn.datatables.net/plug-ins/3cfcc339e89/i18n/Chinese.json'
        },

        //初始化
        "pageLength": 5,
        "columnDefs": [{ // 设置默认列设置
          'orderable': true,
          'targets': [0]
        }, {
          "searchable": true,
          "targets": [0]
        }],
        "order": [
          [0, "asc"]
        ] // 将第一列设置为asc的默认排序
      });

编辑行记录,就是动态增加一些Input控件,让用户可以录入数据,如下代码所示。

//编辑行
        function editRow(oTable, nRow) {
          var aData = oTable.fnGetData(nRow);
          var jqTds = $('>td', nRow);
          jqTds[0].innerHTML = '<input type="text" class="form-control input-small" value="' + aData[0] + '" readonly>';
          jqTds[1].innerHTML = '<input type="text" class="form-control input-small" value="' + aData[1] + '">';
          jqTds[2].innerHTML = '<input type="date" class="form-control input-small" value="' + aData[2] + '">';
          jqTds[3].innerHTML = '<input type="number" class="form-control input-small" value="' + aData[3] + '">';
          jqTds[4].innerHTML = '<input type="text" class="form-control input-small" value="' + aData[4] + '">';
          jqTds[5].innerHTML = '<a class="edit" href="">保存</a>';
          jqTds[6].innerHTML = '<a class="cancel" href="">取消</a>';
        }

保存数据后,通过把记录更新到对应TD对象里面,如下所示。

//费用类型 发生时间 费用金额 费用说明
        var objList = [];  
        //保存行数据,切换到普通模式
        function saveRow(oTable, nRow) {
          var jqInputs = $('input', nRow);
          //更新行中每个input的值
          oTable.fnUpdate(jqInputs[0].value, nRow, 0, false);
          oTable.fnUpdate(jqInputs[1].value, nRow, 1, false);
          oTable.fnUpdate(jqInputs[2].value, nRow, 2, false);
          oTable.fnUpdate(jqInputs[3].value, nRow, 3, false);
          oTable.fnUpdate(jqInputs[4].value, nRow, 4, false);
          oTable.fnUpdate('<a class="edit" href="">编辑</a>', nRow, 5, false);
          oTable.fnUpdate('<a class="delete" href="">删除</a>', nRow, 6, false);
          oTable.fnDraw();
        }

在界面上的几个出来动作按钮,如新增、编辑、保存、删除等按钮处理事件如下所示。

var addRow = 1;
        $('#detail_editable_1_new').click(function (e) {
          e.preventDefault();

          if (nNew && nEditing) {
            if (confirm("前面记录没有保存,您是否需要保存?")) {
              saveRow(oTable, nEditing);
              //$(nEditing).find("td:first").html("未保存");
              nEditing = null;
              nNew = false;
            } else {
              oTable.fnDeleteRow(nEditing); // cancel
              nEditing = null;
              nNew = false;
              return;
            }
          }

          //添加一条新的记录
          var aiNew = oTable.fnAddData([addRow++, '', '', '', '', '', '']);
          var nRow = oTable.fnGetNodes(aiNew[0]);
          editRow(oTable, nRow);
          nEditing = nRow;
          nNew = true;
        });
        //删除操作
        table.on('click', '.delete', function (e) {
          e.preventDefault();
          if (confirm("您确认要删除该行记录吗?") == false) {
            return;
          }
          //获取上一级tr行的数据
          var nRow = $(this).parents('tr')[0];
          var aData = oTable.fnGetData(nRow);

          var found = false;
          $.each(objList, function (i, item) {
            if (item["seq"] == aData[0]) {
              found = true;
              objList.splice(i, 1);
            }
          });
          oTable.fnDeleteRow(nRow);
        });
        //取消操作
        table.on('click', '.cancel', function (e) {
          e.preventDefault();
          if (nNew) {
            oTable.fnDeleteRow(nEditing);
            nEditing = null;
            nNew = false;
          } else {
            restoreRow(oTable, nEditing);
            nEditing = null;
          }
        });
        //编辑操作
        table.on('click', '.edit', function (e) {
          e.preventDefault();
          nNew = false;

          /*获取所击连接的行对象*/
          var nRow = $(this).parents('tr')[0];

          if (nEditing !== null && nEditing != nRow) {
            /* 当前正在编辑 - 但不是此行 - 在继续编辑模式之前恢复旧版 */
            restoreRow(oTable, nEditing);
            editRow(oTable, nRow);
            nEditing = nRow;
          } else if (nEditing == nRow && this.innerHTML == "保存") {
            /* 编辑该行,并准备保存记录 */
            saveRow(oTable, nEditing);
            nEditing = null;

          } else {
            /* No edit in progress - let's start one */
            editRow(oTable, nRow);
            nEditing = nRow;
          }
        });
      }

我们在最后一步,提交数据的时候,就是遍历整个表格,获取每行的数据,并把它们放到JSON对象列表里面,在提交到后台录入即可,如下是获取列表数据的JS代码

//获取表格的数据,并返回对象列表
      function GetData() {
        var list = [];  
        var trs = table.fnGetNodes();
        for (var i = 0; i < trs.length; i++) {
          var data = table.fnGetData(trs[i]);//获取指定行的数据

          var obj = {};
          //obj["seq"] = data[0];//序号
          obj["FeeType"] = data[1];
          obj["OccurTime"] = data[2];
          obj["FeeAmount"] = data[3];
          obj["FeeDescription"] = data[4];
          list.push(obj);
        }
        return list;
      };

获取到表格明细的数据后,我们就是确定如何提交到MVC后台接口来处理了,下面是业务里面关于明细数据提交MVC后台的JS代码。

在Bootstrap开发框架中使用dataTable直接录入表格行数据的方法

后台MVC控制器的C#处理逻辑代码如下所示。

/// <summary>
    /// 保存申请单主从表数据
    /// </summary>
    /// <returns></returns>
    [HttpPost]
    public ActionResult SaveApply(JObject param)
    {
      dynamic obj = param;
      if (obj != null)
      {
        var result = new CommonResult();

        if (obj.info != null)
        {
          //获取主信息
          var info = (JObject.FromObject(obj.info)).ToObject<ReimbursementInfo>();

          //转换为明细信息
          List<ReimbursementDetailInfo> details = null;
          if (obj.details != null)
          {
            details = (JArray.FromObject(obj.details)).ToObject<List<ReimbursementDetailInfo>>();
          }

          if (info != null)
          {
            //修改部分信息
            OnBeforeInsert(info);
            bool succeed = BLLFactory<Reimbursement>.Instance.Insert(info);
            if (succeed)
            {
              if (details != null)
              {
                foreach (var detailInfo in details)
                {
                  //设置关键信息
                  detailInfo.Apply_ID = info.Apply_ID;
                  detailInfo.Header_ID = info.ID;
                  BLLFactory<ReimbursementDetail>.Instance.InsertUpdate(detailInfo, detailInfo.ID);
                }
              }
              result.Success = succeed;
            }
          }
        }
        return ToJsonContent(result);
      }
      else
      {
        throw new MyApiException("传递参数错误");
      }
    }

其中对于提交上来的数据,对象信息用JObject进行转换,而对于明细列表则使用JArray.FromObject进行转换,其他部分就是如何保存主表和明细表的接口了。

上面的处理逻辑和代码就是处理明细表的前台获取,提交处理,以及后台的接口处理,整个过程主要用来介绍在Bootstrap开发框架中使用dataTable直接录入表格行数据。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Extjs中ComboBoxTree实现的下拉框树效果(自写)
May 28 Javascript
js中用window.open()打开多个窗口的name问题
Mar 13 Javascript
解析js如何获取css样式
Dec 11 Javascript
js实现把图片的绝对路径转为base64字符串、blob对象再上传
Dec 29 Javascript
js实现字符全排列算法的简单方法
May 01 Javascript
ztree实现权限横向显示功能
May 20 Javascript
微信小程序实现顶部选项卡(swiper)
Jun 19 Javascript
vue 中Virtual Dom被创建的方法
Apr 15 Javascript
微信小程序下拉菜单效果的实例代码
May 14 Javascript
JavaScript定时器常见用法实例分析
Nov 15 Javascript
微信小程序表单验证WxValidate的使用
Nov 27 Javascript
压缩Vue.js打包后的体积方法总结(Vue.js打包后体积过大问题)
Feb 03 Javascript
浅谈高大上的微信小程序中渲染html内容—技术分享
Oct 25 #Javascript
使用ECharts实现状态区间图
Oct 25 #Javascript
jquery使用FormData实现异步上传文件
Oct 25 #jQuery
详解js访问对象的属性和方法
Oct 25 #Javascript
深入浅析js原型链和vue构造函数
Oct 25 #Javascript
AngularJS 多指令Scope问题的解决
Oct 25 #Javascript
jQuery+Datatables实现表格批量删除功能【推荐】
Oct 24 #jQuery
You might like
echo, print, printf 和 sprintf 区别
2006/12/06 PHP
PHP中error_reporting()函数的用法(修改PHP屏蔽错误)
2011/07/01 PHP
PHP的一个基础知识 表单提交
2011/07/04 PHP
thinkphp autoload 命名空间自定义 namespace
2015/07/17 PHP
Yii开启片段缓存的方法
2016/03/28 PHP
初学js插入节点appendChild insertBefore使用方法
2011/07/04 Javascript
基于JS实现无缝滚动思路及代码分享
2016/06/07 Javascript
jQuery实现的tab标签切换效果示例
2016/09/05 Javascript
微信小程序  自定义创建详细介绍
2016/10/27 Javascript
js实现的在线调色板功能完整实例
2016/12/21 Javascript
详解webpack进阶之插件篇
2017/07/06 Javascript
小程序云开发获取不到数据库记录的解决方法
2019/05/18 Javascript
判断JavaScript中的两个变量是否相等的操作符
2019/12/21 Javascript
基于javascript canvas实现五子棋游戏
2020/07/08 Javascript
js实现省级联动(数据结构优化)
2020/07/17 Javascript
微信小程序实现打卡签到页面
2020/09/21 Javascript
如何实现vue的tree组件
2020/12/03 Vue.js
python之模拟鼠标键盘动作具体实现
2013/12/30 Python
python列表操作使用示例分享
2014/02/21 Python
Python实现测试磁盘性能的方法
2015/03/12 Python
Python中生成Epoch的方法
2017/04/26 Python
python 实现数组list 添加、修改、删除的方法
2018/04/04 Python
python pygame实现五子棋小游戏
2020/10/26 Python
python修改字典键(key)的方法
2019/08/05 Python
Python中函数的返回值示例浅析
2019/08/28 Python
pyCharm 实现关闭代码检查
2020/06/09 Python
python实现猜拳游戏项目
2020/11/30 Python
几个数据库方面的面试题
2016/07/01 面试题
党的群众路线教育实践活动心得体会900字
2014/03/07 职场文书
2014领导干部四风问题查摆思想汇报
2014/09/13 职场文书
2014国庆65周年领导讲话稿(3篇)
2014/09/21 职场文书
通讯稿格式及范文
2015/07/22 职场文书
读《瓦尔登湖》有感:每个人都需要一个瓦尔登湖
2019/10/17 职场文书
mysql中int(3)和int(10)的数值范围是否相同
2021/10/16 MySQL
golang操作rocketmq的示例代码
2022/04/06 Golang
详解Flutter自定义应用程序内键盘的实现方法
2022/06/14 Java/Android