java表格的编辑_JQuery实现可编辑的表格

点击表格后可直接编辑,回车或鼠标点击页面其他地方后编辑生效,按Esc可取消编辑

第一种单击表格可以编辑的方法

//相当于在页面中的 body标签加上onload事件

$(function() {

//找到所有的td节点

var tds = $("td");

//给所有的td添加点击事件

tds.click(function() {

//获得当前点击的对象

var td = $(this);

//取出当前td的文本内容保存起来

var oldText = td.text();

//建立一个文本框,设置文本框的值为保存的值

var input = $("");

//将当前td对象内容设置为input

td.html(input);

//设置文本框的点击事件失效

input.click(function() {

return false;

});

//设置文本框的样式

input.css("border-width", "0");

input.css("font-size", "16px");

input.css("text-align", "center");

//设置文本框宽度等于td的宽度

input.width(td.width());

//当文本框得到焦点时触发全选事件

input.trigger("focus").trigger("select");

//当文本框失去焦点时重新变为文本

input.blur(function() {

var input_blur = $(this);

//保存当前文本框的内容

var newText = input_blur.val();

td.html(newText);

});

//响应键盘事件

input.keyup(function(event) {

// 获取键值

var keyEvent = event || window.event;

var key = keyEvent.keyCode;

//获得当前对象

var input_blur = $(this);

switch (key)

{

case 13://按下回车键,保存当前文本框的内容

var newText = input_blur.val();

td.html(newText);

break;

case 27://按下 esc键,取消修改,把文本框变成文本

td.html(oldText);

break;

}

});

});

});

第二种单击表格可以编辑的方法

$(document).ready(function(){

var tds = $("td");

tds.click(tdClick);

});

function tdClick(){

var tdnode = $(this);

var tdtext = tdnode.text();

tdnode.html("");

var input = $("");

input.val(tdtext); //    input.attr("value",tdtext);

input.keyup(function(event){

var myEvent = event || window.event;

var keyCode = myEvent.keyCode;

if(keyCode == 13){

var inputnode = $(this);

var inputtext = inputnode.val();

var td = inputnode.parent();

td.html(inputtext);

td.click(tdClick);

}

if(keyCode == 27){  //判断是否按下ESC键

$(this).parent().html(tdtext);

$(this).parent().click(tdClick);

}

});

tdnode.append(input);

tdnode.children("input").trigger("select");

//输入框失去焦点,所执行的方法

input.blur(function(){

tdnode.html($(this).val());

tdnode.click(tdClick);

});

tdnode.unbind("click");

}

posted on 2010-07-05 08:51 kxbin 阅读(1831) 评论(1)  编辑  收藏 所属分类: AJAX

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值