实现思路
目前想到两个方法,方法一从网上找的,比较朴素,在原表格上修改,方法二是在实际项目采用的,先把表格。
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>