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;

  });

 });

});

时间: 2025-01-16 07:24:12

JQuery实现可直接编辑的表格的相关文章

小谷实战Jquery(二)--可以编辑的表格

今天实现的是一个表格的例子,通过获取表格的奇数行,设置背景色属性,使得奇偶行背景色不同.这个表格可以在单击时编辑,回车即更改为新输入的内容;ESC还原最初的文本.表格的实现思路很清晰,只是在实现的过程中会出现一些小bug.通过jQuery函数就可以一一解决. 下面看下HTML代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD

JQuery实战--可以编辑的表格

今天学习到了一个实例,其名称为的可以编辑的表格.其实现的效果是:点击页面上的单元格,单元格中的内容变成选中状态,变成可以输入的状态,向单元格中输入内容,按下回车,单元格保存其修改后的结果,按ESC,单元格的内容还原成原来的内容.其原理是:点击单元格的时候,在单元格内添加一个文本框,其大小充满整个单元格,其内容为单元格中的内容,修改后的内容重新赋给单元格. HTML代码: <span style="font-size:18px;"><!DOCTYPE html>

jQuery——可以编辑的表格

今天学习了利用jQuery实现可以编辑的表格这个例子.这个例子需求是这样的:在前台的表格中单击单元格便可修改其中的内容,回车键保存修改的内容,esc撤销保存的内容.原理:单击客户端表格单元格时,在单元格中添加一个文本框,并将单元格中原来的内容赋值给文本框,再进一步去修改文本框内容,修改后将文本框内容重新赋值给单元格. 源码: 前台代码: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="

实战Jquery(二)--能够编辑的表格

今天实现的是一个表格的样例,通过获取表格的奇数行,设置背景色属性,使得奇偶行背景色不同.这个表格能够在单击时编辑,回车即更改为新输入的内容;ESC还原最初的文本.表格的实现思路非常清晰,仅仅是在实现的过程中会出现一些小bug.通过jQuery函数就能够一一解决. 以下看下HTML代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/D

可编辑的表格:jQuery+PHP实现实时编辑表格字段内容

在本例中,我们会通过jQuery实现单击将一个文本信息变为可编辑的表单,你可以对文本内容进行编辑,然后点击“确定”按钮,新的内容将发送到后台PHP程序处理,并保存到数据库:当点击“取消”按钮,则页面恢复到初始状态. 查看演示 下载源码 本例适用场景:当查看详细资料,如用户详情信息,发现其中某几个字段信息需要修改,可直接点击该字段内容进行修改,节约了用户时间,(传统的做法是进入一个编辑页面,列出所有编辑的字段信息,即使你只需要编辑其中一两个字段内容,然后点击提交)提高了WEB响应速度,从而提高了前

JQuery结合Ajax实现双击Table表格,使Table变成可编辑,并保存到数据库中

近期在做项目时,要实现通过双击Table表格的TR,使Table行变成可编辑,来实现修改数据并保存到数据库中的功能,无需多说,直接贴代码吧.希望能得到各位同仁指正. 1 function tdEdit(element, id) { 2 var i_a = "<input class='edit_td' type='text' style='height:30px; width:40px;' value='"; 3 var i_b = "'/>"; 4 v

Jquery easyui开启行编辑模式增删改操作

来源:http://www.cnblogs.com/nyzhai/archive/2013/05/14/3077152.html Jquery easyui开启行编辑模式增删改操作先上图 Html代码: <table id="dd"> </table> 引入JS文件和CSS样式 <script src="http://www.cnblogs.com/Resources/jquery-easyui-1.2.3/jquery-1.4.4.min.js

[转]Jquery easyui开启行编辑模式增删改操作

本文转自:http://www.cnblogs.com/nyzhai/archive/2013/05/14/3077152.html Jquery easyui开启行编辑模式增删改操作先上图 Html代码: <table id="dd"> </table> 引入JS文件和CSS样式 <script src="http://www.cnblogs.com/Resources/jquery-easyui-1.2.3/jquery-1.4.4.min.

JS实现可编辑的表格,双击可编辑,可以删除行和列,增加行和列,重置,导出表格,也可以上下移动元素

JS实现可编辑的表格,双击可编辑,可以删除行和列,增加行和列,重置,导出表格,也可以上下移动元素  原文:JS实现可编辑的表格,双击可编辑,可以删除行和列,增加行和列,重置,导出表格,也可以上下移动元素 源代码下载地址:http://www.zuidaima.com/share/1550463322606592.htm 源代码截图: JS实现可编辑的表格,双击可编辑,可以删除行和列,增加行和列,重置,导出表格,也可以上下移动元素