JQuery实现可直接编辑的表格

Posted 山涧清泉

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JQuery实现可直接编辑的表格相关的知识,希望对你有一定的参考价值。

本文实例讲述了JQuery实现可直接编辑的表格。分享给大家供大家参考。具体分析如下:

功能:

创建一个表格,用户单击某个单元格后,可以直接修改单元格文本。
在编辑状态下,用户可按回车键确认修改,按ESC键撤销修改。

效果如下图:

技术分享

 

思路:

当用户点击某个单元格后,立即向该单元格内插入一个文本框,将它的宽、高都设置成与单元格相的数值。用户确认输入后,清空该单元格内的所有html代码,然后把内容设置为用户刚刚输入的文本。

HTML代码:

<table align="center">
 <tr>
 <td>学号</td>
 <td>姓名</td>
 </tr>
 <tr>
 <td>001</td>
 <td>dog</td>
 </tr>
 <tr>
 <td>002</td>
 <td>cat</td>
 </tr>
 <tr>
 <td>003</td>
 <td>pig</td>
 </tr>
</table>
JavaScript代码:
$(function(){
 $("td").click(function(event){
  //td中已经有了input,则不需要响应点击事件
  if($(this).children("input").length > 0)
   return false;
  var tdObj = $(this);
  var preText = tdObj.html();
  //得到当前文本内容
  var inputObj = $("<input type=‘text‘ />");
  //创建一个文本框元素
  tdObj.html(""); //清空td中的所有元素
  inputObj
   .width(tdObj.width())
   //设置文本框宽度与td相同
   .height(tdObj.height())
   .css({border:"0px",fontSize:"17px",font:"宋体"})
   .val(preText)
   .appendTo(tdObj)
   //把创建的文本框插入到tdObj子节点的最后
   .trigger("focus")
   //用trigger方法触发事件
   .trigger("select");
  inputObj.keyup(function(event){
   if(13 == event.which)
   //用户按下回车
   {
    var text = $(this).val();
    tdObj.html(text);
   }
   else if(27 == event.which)
   //ESC键
   {
    tdObj.html(preText);
   }
  });
  //已进入编辑状态后,不再处理click事件
  inputObj.click(function(){
   return false;
  });
 });
});

以上是关于JQuery实现可直接编辑的表格的主要内容,如果未能解决你的问题,请参考以下文章

jquery 双击可编辑表格怎么做呢。

Notepad++编辑器——Verilog代码片段直接编译

基于Birt4.6实现报表表格数据的可编辑

Swift - 可编辑表格样例(可直接编辑单元格中内容移动删除单元格)

实战Jquery--能够编辑的表格

用jquery设置下拉不可编辑,但是没起作用,求高手指点,急。。。