收藏 不显示删除回复显示所有回复显示星级回复显示得分回复 JQuery实现可编辑的表格,怎样添加php代码
<form id="form1" name="form1" method="post" action="">
<table style="table-layout:fixed;word-break:break-all" border="2">
<tbody id="goaler">
<?
.............//读取记录到数组$obj[$i][0]、$obj[$i][1]的代码省略掉
for($i=0;$i <count($obj);$i++) {
echo " <tr> <td width='10%'>".$obj[$i][0]." </td>";
echo " <td width='10%'>".$obj[$i][1]." </td>";
echo " </tr>";
}
//通过php将记录显示在表格中,我想要在线编辑,加了下面的AJAX。问题是JS中获取要保存的TD节点,怎么转换成PHP中的obj数组保存下来?
?>
</tbody>
</table>
</form>
<script language="javascript">
<!--
var TbRow = document.getElementById("goaler");
if (TbRow != null) {
for (var i=0;i <TbRow.rows.length ;i++ ) {
if (TbRow.rows[i].rowIndex%2==1){
TbRow.rows[i].style.backgroundColor="#e5f1f4";
}
else {
TbRow.rows[i].style.backgroundColor="#F1F1F1";
}
}
}
$(function(){
//找到所有的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());
//当文本框得到焦点时触发全选事件
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>