html在线编辑表格,JQuery实现可直接编辑的表格

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

功能:

创建一个表格,用户单击某个单元格后,可以直接修改单元格文本。

在编辑状态下,用户可按回车键确认修改,按ESC键撤销修改。

效果如下图:

432cbb2c14520579b79534f7e4051bcf.png

思路:

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

HTML代码:

学号姓名
001dog
002cat
003pig

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 = $("");

//创建一个文本框元素

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程序设计有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值