基于Bootstrap使用jQuery实现简单可编辑表格


Posted in Javascript onMay 04, 2016

editTable.js 提供编辑表格当前行、添加一行、删除当前行的操作,其中可以设置参数,如:

operatePos 用于设置放置操作的列,从0开始,-1表示以最后一列作为放置操作的列;(这里的操作包括 编辑当前行、在当前行下添加一行、删除当前行)

handleFirst 设置表格的第一行是否作为操作的对象,true为真,false为假;

edit、save、cancel、add、confirm、del 分别设置显示操作的操作名,默认显示“编辑”、“保存”、“取消”、“添加”、“确认”、“删除”字样;

editableCols 设置可被编辑的列,从0开始,以数组形式进行设置,如 [ 1, 2] ,表示第2、3列进行编辑操作时,可以被编辑;可以传入 "all" ,表示选中所有列可被编辑;当然程序中会自动排除 已经设置要放置操作的列;

order 设置表格需要的操作,同时可以设置操作排放的顺序;参数为数组形式,数组中的值可以为edit、add、del;传入空数组的话,默认提供edit编辑操作,相当于设置 [ "edit" ] 参数;此外默认提供所有功能,即编辑、添加、删除,相当于设置 [ "edit", "add", "del"] 参数,且顺序为编辑-》添加-》删除;可以修改三者的顺序,如 [ "add", "edit", "del" ];

saveCallback 当提供编辑功能后,在编辑当前行的过程中,点击保存后的回调函数;需要用户在使用编辑功能的同时,设置该参数,当进行保存过中,该函数可以使用ajax传递编辑后的数据data(保存在data数组中),当ajax保存数据成功后应该还需要调用函数 参数中的 isSuccess 方法,以修改界面中的可编辑状态为不可编辑状态;

addCallback和delCallback与saveCallback同理,只是分别应用在不同的操作上——添加和删除。

editTable.js

/** 
 * Created by DreamBoy on 2016/4/19. 
 */ 
$(function() { 
 $.fn.handleTable = function (options) { 
 //1.Settings 初始化设置 
 var c = $.extend({ 
  "operatePos" : -1, //-1表示默认操作列为最后一列 
  "handleFirst" : false, //第一行是否作为操作的对象 
  "edit" : "编辑", 
  "save" : "保存", 
  "cancel" : "取消", 
  "add" : "添加", 
  "confirm" : "确认", 
  "del" : "删除", 
  "editableCols" : "all", //可编辑的列,从0开始 
  //"pos" : 0, //位置位于该列开头,还是结尾(左侧或右侧) 
  "order" : ["edit", "add", "del"], //指定三个功能的顺序 
  "saveCallback" : function(data, isSuccess) { //这里可以写ajax内容,用于保存编辑后的内容 
  //data: 返回的数据 
  //isSuccess: 方法,用于保存数据成功后,将可编辑状态变为不可编辑状态 
  //ajax请求成功(保存数据成功),才回调isSuccess函数(修改保存状态为编辑状态) 
  }, 
  "addCallback" : function(data, isSuccess) { 
  //isSuccess: 方法,用于添加数据成功后,将可编辑状态变为不可编辑状态 
  }, 
  "delCallback" : function(isSuccess) { 
  //isSuccess: 方法,用于删除数据成功后,将对应行删除 
  } 
 }, options); 
 
 //表格的列数 
 var colsNum = $(this).find('tr').last().children().size(); 
 
 //2.初始化操作列,默认为最后一列,从1算起 
 if(c.operatePos == -1) { 
  c.operatePos = colsNum - 1; 
 } 
 
 //3.获取所有需要被操作的行 
 var rows = $(this).find('tr'); 
 if(!c.handleFirst) { 
  rows = rows.not(":eq(0)"); 
 } 
 
 //4.获取放置“操作”的列,通过operatePos获取 
 var rowsTd = []; 
 var allTd = rows.children(); 
 for(var i = c.operatePos; i <= allTd.size(); i += colsNum) { 
  if(c.handleFirst) { //如果操作第一行,就把放置操作的列内容置为空 
  allTd.eq(i).html(""); 
  } 
  rowsTd.push(allTd.eq(i)[0]); 
 } 
 
 //6.修改设置 order 为空时的默认值 
 if(c.order.length == 0) { 
  c.order = ["edit"]; 
 } 
 
 //7.保存可编辑的列 
 var cols = getEditableCols(); 
 
 //8.初始化链接的构建 
 var saveLink = "", cancelLink = "", editLink = "", addLink = "", confirmLink = "", delLink = ""; 
 initLink(); 
 
 //9.初始化操作 
 initFunc(c.order, rowsTd); 
 
 /** 
  * 创建操作链接 
  */ 
 function createLink(str) { 
  return "<a href=\"javascript:void(0)\" style=\"margin:0 3px\">" + str + "</a>"; 
 } 
 /** 
  * 初始各种操作的链接 
  */ 
 function initLink() { 
  for(var i = 0; i < c.order.length; i++) { 
  switch (c.order[i]) { 
   case "edit": 
   //“编辑”链接 
   editLink = createLink(c.edit); 
   saveLink = createLink(c.save); 
   cancelLink = createLink(c.cancel); 
   break; 
   case "add": 
   //“添加”链接 
   addLink = createLink(c.add); 
   //“确认”链接 
   confirmLink = createLink(c.confirm); 
   //“取消”链接 
   cancelLink = createLink(c.cancel); 
   break; 
   case "del": 
   //“删除”链接 
   delLink = createLink(c.del); 
   break; 
  } 
  } 
 } 
 
 /** 
  * 获取可进行编辑操作的列 
  */ 
 function getEditableCols() { 
  var cols = c.editableCols; 
  if($.type(c.editableCols) != "array" && cols == "all") { //如果是所有列都可以编辑的话 
  cols = []; 
  for(var i = 0; i < colsNum; i++) { 
   if(i != c.operatePos) { //排除放置操作的列 
   cols.push(i); 
   } 
  } 
  } else if($.type(c.editableCols) == "array") { //有指定选择编辑的列的话需要排序放置“编辑”功能的列 
  var copyCols = []; 
  for(var i = 0; i < cols.length; i++) { 
   if(cols[i] != c.operatePos) { 
   copyCols.push(cols[i]); 
   } 
  } 
  cols = copyCols; 
  } 
  return cols; 
 } 
 
 /** 
  * 根据c.order参数设置提供的操作 
  * @param func 需要设置的操作 
  * @param cols 放置操作的列 
  */ 
 function initFunc(func, cols) { 
  for(var i = 0; i < func.length; i++) { 
  var o = func[i]; 
  switch(o) { 
   case "edit": 
   createEdit(cols); 
   break; 
   case "add": 
   createAdd(cols); 
   break; 
   case "del": 
   createDel(cols); 
   break; 
  } 
  } 
 } 
 
 /** 
  * 创建“编辑一行”的功能 
  * @param operateCol 放置编辑操作的列 
  */ 
 function createEdit(operateCol) { 
  $(editLink).appendTo(operateCol).on("click", function() { 
  if(replaceQuote($(this).html()) == replaceQuote(c.edit)) { //如果此时是编辑状态 
   toSave(this); //将编辑状态变为保存状态 
  } else if(replaceQuote($(this).html()) == replaceQuote(c.save)) { //如果此时是保存状态 
   var p = $(this).parents('tr'); //获取被点击的当前行 
   var data = []; //保存修改后的数据到数据内 
   for(var i = 0; i < cols.length; i++) { 
   var tr = p.children().eq(cols[i]); 
   var inputValue = tr.children('input').val(); 
   data.push(inputValue); 
   } 
 
   $this = this; //此时的this表示的是 被点击的 编辑链接 
   c.saveCallback(data, function() { 
   toEdit($this, true); 
   }); 
  } 
  }); 
  var afterSave = []; //保存修改前的信息,用于用户点击取消后的数值返回操作 
  //修改为“保存”状态 
  function toSave(ele) { 
  $(ele).html(c.save); //修改为“保存” 
  $(ele).after(cancelLink); //添加相应的取消保存的“取消链接” 
  $(ele).next().on('click', function() { 
   //if($(this).html() == c.cancel.replace(eval("/\'/gi"),"\"")) { 
   toEdit(ele, false); 
   //} 
  }); 
 
  //获取被点击编辑的当前行 tr jQuery对象 
  var p = $(ele).parents('tr'); 
 
  afterSave = []; //清空原来保存的数据 
  for(var i = 0; i < cols.length; i++) { 
   var tr = p.children().eq(cols[i]); 
   var editTr = "<input type=\"text\" class=\"form-control\" value=\"" + tr.html() + "\"/>"; 
   afterSave.push(tr.html()); //保存未修改前的数据 
   tr.html(editTr); 
  } 
  } 
  //修改为“编辑”状态(此时,需要通过isSave标志判断是 
  // 因为点击了“保存”(保存成功)变为“编辑”状态的,还是因为点击了“取消”变为“编辑”状态的) 
  function toEdit(ele, isSave) { 
  $(ele).html(c.edit); 
  if(replaceQuote($(ele).next().html()) == replaceQuote(c.cancel)) { 
   $(ele).next().remove(); 
  } 
 
  var p = $(ele).parents('tr'); 
 
  for(var i = 0; i < cols.length; i++) { 
   var tr = p.children().eq(cols[i]); 
   var value; 
   if(isSave) { 
   value = tr.children('input').val(); 
   } else { 
   value = afterSave[i]; 
   } 
 
   tr.html(value); 
  } 
  } 
 } 
 
 /** 
  * 创建“添加一行”的功能 
  * @param operateCol 
  */ 
 function createAdd(operateCol) { 
  $(addLink).appendTo(operateCol).on("click", function() { 
  //获取被点击“添加”的当前行 tr jQuery对象 
  var p = $(this).parents('tr'); 
  var copyRow = p.clone(); //构建新的一行 
  var input = "<input type=\"text\"/>"; 
  var childLen = p.children().length; 
  for(var i = 0; i < childLen; i++) { 
   copyRow.children().eq(i).html("<input type=\"text\" class=\"form-control\"/>"); 
  } 
 
  //最后一行是操作行 
  var last = copyRow.children().eq(c.operatePos); 
  last.html(""); 
  p.after(copyRow); 
 
  var confirm = $(confirmLink).appendTo(last).on("click", function() { 
   var data = []; 
   for(var i = 0; i < childLen; i++) { 
   if(i != c.operatePos) { 
    var v = copyRow.children().eq(i).children("input").val(); 
    data.push(v); 
    copyRow.children().eq(i).html(v); 
   } 
   } 
   c.addCallback(data, function() { 
   last.html(""); 
   //------------这里可以进行修改 
   initFunc(c.order, last); 
   }); 
  }); 
 
  $(confirm).after(cancelLink); //添加相应的取消保存的“取消链接” 
  $(confirm).next().on('click', function() { 
   copyRow.remove(); 
  }); 
  }); 
 } 
 
 /** 
  * 创建“删除一行”的功能 
  * @param operateCol 
  */ 
 function createDel(operateCol) { 
  $(delLink).appendTo(operateCol).on("click", function() { 
  var _this = this; 
  c.delCallback(function() { 
   $(_this).parents('tr').remove(); 
  }); 
  }); 
 } 
 
 /** 
  * 将str中的单引号转为双引号 
  * @param str 
  */ 
 function replaceQuote(str) { 
  return str.replace(/\'/g, "\""); 
 } 
 }; 
});

使用过程中需要注意:需要在对应的table中加入可选择到的选择器,还有需要在放置”操作“的列放置空标签<td></td>用于存放”操作“。

使用案例如下:

目录结构:

基于Bootstrap使用jQuery实现简单可编辑表格

index.html

<!DOCTYPE html> 
<html lang="en"> 
<head> 
 <meta charset="UTF-8"> 
 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 
 <meta name="viewport" content="width=device-width, initial-scale=1"> 
 <title>表格</title> 
 <link rel="stylesheet" href="css/bootstrap.min.css" type="text/css"> 
 <!--<link href="assets/font-awesome/css/font-awesome.css" rel="stylesheet" />--> 
 <!--[if lt IE 9]> 
 <script src="js/html5shiv.js"></script> 
 <script src="js/respond.min.js"></script> 
 <![endif]--> 
</head> 
<body> 
 <div class="container"> 
 <div class="bs-example" data-example-id="hoverable-table"> 
  <table class="table table-hover editable"> 
  <thead> 
  <tr> 
   <th>#</th> 
   <th>Test</th> 
   <th>First Name</th> 
   <th>Last Name</th> 
   <th>Username</th> 
   <th>Operations</th> 
  </tr> 
  </thead> 
  <tbody> 
  <tr> 
   <th scope="row">1</th> 
   <td></td> 
   <td>Mark</td> 
   <td>Otto</td> 
   <td>@mdo</td> 
   <td><!--<a href="javascript:void(0)" class="edit"></a>--></td> 
  </tr> 
  <tr> 
   <th scope="row">2</th> 
   <td></td> 
   <td>Jacob</td> 
   <td>Thornton</td> 
   <td>@fat</td> 
   <td><!--<a href="javascript:void(0)" class="edit"></a>--></td> 
  </tr> 
  <tr> 
   <th scope="row">3</th> 
   <td></td> 
   <td>Larry</td> 
   <td>the Bird</td> 
   <td>@twitter</td> 
   <td><!--<a href="javascript:void(0)" class="edit"></a>--></td> 
  </tr> 
  </tbody> 
  </table> 
 </div> 
 </div> 
 
 <script src="js/jquery-1.11.1.min.js"></script> 
 <script src="js/bootstrap.min.js"></script> 
 <script src="editTable.js"></script> 
 <script> 
 $(function() { 
  //$('.edit').handleTable({"cancel" : "<span class='glyphicon glyphicon-remove'></span>"}); 
  $('.editable').handleTable({ 
  "handleFirst" : true, 
  "cancel" : " <span class='glyphicon glyphicon-remove'></span> ", 
  "edit" : " <span class='glyphicon glyphicon-edit'></span> ", 
  "add" : " <span class='glyphicon glyphicon-plus'></span> ", 
  "save" : " <span class='glyphicon glyphicon-saved'></span> ", 
  "confirm" : " <span class='glyphicon glyphicon-ok'></span> ", 
  "operatePos" : -1, 
  "editableCols" : [2,3,4], 
  "order": ["add","edit"], 
  "saveCallback" : function(data, isSuccess) { //这里可以写ajax内容,用于保存编辑后的内容 
   //data: 返回的数据 
   //isSucess: 方法,用于保存数据成功后,将可编辑状态变为不可编辑状态 
   var flag = true; //ajax请求成功(保存数据成功),才回调isSuccess函数(修改保存状态为编辑状态) 
   if(flag) { 
   isSuccess(); 
   alert(data + " 保存成功"); 
   } else { 
   alert(data + " 保存失败"); 
   } 
 
   return true; 
  }, 
  "addCallback" : function(data,isSuccess) { 
   var flag = true; 
   if(flag) { 
   isSuccess(); 
   alert(data + " 增加成功"); 
   } else { 
   alert(data + " 增加失败"); 
   } 
  }, 
  "delCallback" : function(isSuccess) { 
   var flag = true; 
   if(flag) { 
   isSuccess(); 
   alert("删除成功"); 
   } else { 
   alert("删除失败"); 
   } 
  } 
  }); 
 }); 
 </script> 
</body> 
</html>

运行结果如下

基于Bootstrap使用jQuery实现简单可编辑表格

使用编辑操作:

进行修改:

基于Bootstrap使用jQuery实现简单可编辑表格

点击保存:

基于Bootstrap使用jQuery实现简单可编辑表格

基于Bootstrap使用jQuery实现简单可编辑表格

添加多行:

基于Bootstrap使用jQuery实现简单可编辑表格

在其中添加一些数据:

基于Bootstrap使用jQuery实现简单可编辑表格

点击“确定”:

基于Bootstrap使用jQuery实现简单可编辑表格

基于Bootstrap使用jQuery实现简单可编辑表格

可以取消其他多余要添加的行:

基于Bootstrap使用jQuery实现简单可编辑表格

如果大家还想深入学习,可以点击这里进行学习,再为大家附3个精彩的专题:

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
JavaScript 获取用户客户端操作系统版本
Aug 25 Javascript
jquery无法设置checkbox选中即没有变成选中状态
Mar 27 Javascript
浅谈javascript的调试
Jan 28 Javascript
ANGULARJS中使用JQUERY分页控件
Sep 16 Javascript
详解js运算符单竖杠“|”与“||”的用法和作用介绍
Nov 04 Javascript
常用原生js自定义函数总结
Nov 20 Javascript
Three.js 再探 - 写一个微信跳一跳极简版游戏
Jan 04 Javascript
微信小程序实现轨迹回放的示例代码
Dec 13 Javascript
vue cli3适配所有端方案的实现
Apr 13 Javascript
Vue CLI3移动端适配(px2rem或postcss-plugin-px2rem)
Apr 27 Javascript
JS实现手写 forEach算法示例
Apr 29 Javascript
JS+Canvas实现五子棋游戏
Aug 26 Javascript
纯JS代码实现气泡效果
May 04 #Javascript
DWR中各种java方法的调用
May 04 #Javascript
js实现div在页面拖动效果
May 04 #Javascript
JS功能代码集锦
May 04 #Javascript
Markdown与Bootstrap相结合实现图片自适应属性
May 04 #Javascript
浅析Bootstrap组件之面板组件
May 04 #Javascript
javascript截图 jQuery插件imgAreaSelect使用详解
May 04 #Javascript
You might like
php数组对百万数据进行排除重复数据的实现代码
2010/06/08 PHP
zend framework文件上传功能实例代码
2013/12/25 PHP
PHP查询快递信息的方法
2015/03/07 PHP
PHP多文件上传实例
2015/07/09 PHP
一个完整的php文件上传类实例讲解
2015/10/27 PHP
laravel框架创建授权策略实例分析
2019/11/22 PHP
PHP与Web页面交互操作实例分析
2020/06/02 PHP
简单三步,搞掂内存泄漏
2007/03/10 Javascript
基于jquery的实现简单的表格中增加或删除下一行
2010/08/01 Javascript
JavaScript 变量作用域分析
2011/07/04 Javascript
JQuery-tableDnD 拖拽的基本使用介绍
2013/07/04 Javascript
用js提交表单解决一个页面有多个提交按钮的问题
2014/09/01 Javascript
apply和call方法定义及apply和call方法的区别
2015/11/15 Javascript
JavaScript常用正则验证函数实例小结【年龄,数字,Email,手机,URL,日期等】
2017/01/23 Javascript
浅谈angular4生命周期钩子
2017/09/05 Javascript
微信小程序数字滚动插件使用详解
2018/02/02 Javascript
NodeJs入门教程之定时器和队列
2019/03/08 NodeJs
前后端常见的几种鉴权方式(小结)
2019/08/04 Javascript
微信小程序嵌入腾讯视频源过程详解
2019/08/08 Javascript
vue使用prop可以渲染但是打印台报错的解决方式
2019/11/13 Javascript
微信小程序8种数据通信的方式小结
2020/02/03 Javascript
解决Nuxt使用axios跨域问题
2020/07/06 Javascript
Python中创建二维数组
2018/10/17 Python
python定位xpath 节点位置的方法
2019/08/27 Python
python Django框架实现web端分页呈现数据
2019/10/31 Python
Python魔法方法 容器部方法详解
2020/01/02 Python
Python找出列表中出现次数最多的元素三种方式
2020/02/24 Python
基于tensorflow for循环 while循环案例
2020/06/30 Python
css3实现顶部社会化分享按钮示例
2014/05/06 HTML / CSS
详解CSS3的box-shadow属性制作边框阴影效果的方法
2016/05/10 HTML / CSS
安全生产汇报材料
2014/02/17 职场文书
励志演讲稿600字
2014/08/21 职场文书
党的群众路线教育实践活动个人整改方案
2014/09/21 职场文书
农村文化建设标语
2014/10/07 职场文书
遗嘱继承权公证书
2015/01/26 职场文书
Python实现byte转integer
2021/06/03 Python