項目做完,在測試驗收時,用戶突然提出,可以更改查詢結果,便於打印。隱藏工程錯誤。但是這個時候提要求,比較頭痛,後來,想了想還是用前台代碼,這樣,只要在項目的JS文件中,加入以下幾個函數,便可以解決了。
復制代碼 代碼如下:
/*
頁面裝載時,為每個td增加單擊事件,這樣,就可以不用對每個頁面進行更改。
*/
function ReWritable()
{
var tbmian=document.getElementById("tbmain");
for(var i=0;i<tbmain.rows.length;i++)
{
for(var j=0;j<tbmain.rows[i].cells.length;j++)
{
/*
添加單擊事件屬性。此處不可使用setAttribute方法。
*/
tbmain.rows[i].cells[j].onclick=AddObjOfText;
}
}
}
/*
單擊事件,將Td內容更新為一個Div,其中裝載了一個Text,用於用戶輸入新的Td的值,
一個確定按鈕,一個取消按鈕,用於保存或取消用戶的輸入內容。
一個Hidden,保存用戶輸入新值前的Td的值,以便用戶取消時恢復。
*/
function AddObjOfText()
{
var tdcag=document.getElementById("tdcag");
if(tdcag!=null)
{
return;
}
var tdid=window.event.srcElement;
var tdtxt=tdid.innerText;
var str="<div id='tdcag'><input type='text' id='txtId' value='"+tdtxt+"'>";
str+="<input type='button' value='確定' onclick='ChangeTdText()'>";
str+="<input type='button' value='取消' onclick='CancelTdChanged()'>";
str+="<input type='hidden' id='tdInitValue' value='"+tdtxt+"'>";
str+="</div>";
tdid.innerHTML=str;
}
/*
取消更改,把Hidden值賦給Td
*/
function CancelTdChanged()
{
var tdInitValue=document.getElementById("tdInitValue");
var tdtxt=tdInitValue.value;
var tdid=document.getElementById("tdcag").parentNode;
tdid.innerText=tdtxt;
}
/*
保存用戶更改,把Text值賦值給Td
*/
function ChangeTdText()
{
var txtId=document.getElementById("txtId");
var tdid=document.getElementById("tdcag").parentNode;
tdid.innerText=txtId.value;
}
這樣,在頁面的<body>中,添加onload事件,其值賦為:ReWritable(),如下:
復制代碼 代碼如下:
<body onload="ReWritable();">
<table id="tbmain" style="width:100%;" border="1">
<tr>
<td>11
</td>
<td>12
</td>
<td>13
</td>
</tr>
<tr>
<td>21
</td>
<td>22
</td>
<td>23
</td>
</tr>
<tr>
<td>31
</td>
<td>32
</td>
<td>33
</td>
</tr>
</table>
</body>
這樣,每個Td中,便添加了一個單擊事件。