Javascript编辑表格元素

实现思路

目前想到两个方法,方法一从网上找的,比较朴素,在原表格上修改,方法二是在实际项目采用的,先把表格。

1.方法一:jQuery方法找到表格的元素用click()事件使用html()方法把td替换成input,修改完之后再把input的值赋值给所在表格元素,再把input替换。(不用html(),也可以用append()方法,只不过再用append()时多记得remove这个input()
2.方法二:直接先把表格table.empty(),然后重新插入td,tr,记得把input样式调整表格元素正常大小。

测试页面

将代码粘贴到编译器
https://www.runoob.com/try/try.php?filename=bootstrap3-plugin-modal-event

代码示例

方法一代码:

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8"> 
	<title>Edit Table Cell Sample</title>
	<link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css">
	<script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>
	<script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
	
<body>
<table>
	<tr>
		<td>1</td>
		<td>2</td>
		<td>3</td>
	</tr>
	<tr>
		<td>1</td>
		<td>2</td>
		<td>3</td>
	</tr>
	<tr>
		<td>1</td>
		<td>2</td>
		<td>3</td>
	</tr>
</table>
</body>
	
<script type="text/javascript">
$(function() {
	$('table').width('400').css('border','1px red solid').css('border-collapse','collapse').css('margin','10px auto');
	$('tr td').width('100').height('50').css('border','1px red solid').css('text-align','center');
    //找到所有的td节点
    var tds = $("td");
    //给所有的td添加点击事件
    tds.click(function() {
        //获得当前点击的对象
        var td = $(this);
        //取出当前td的文本内容保存起来
        var oldText = td.text();
        //建立一个文本框,设置文本框的值为保存的值
        var input = $("<input type='text' value='" + oldText + "'/>");
        //将当前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());
        //设置文本框高度等于td的高度
        input.height(td.height());
        //当文本框得到焦点时触发全选事件
        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;
            }
        });
    });
});
	</script>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值