/*
頁面裝載時,為每個td增加單擊事件,這樣,就可以不用對每個頁面進行更改。
添加單擊事件屬性。此處不可使用setAttribute方法。
*/
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;
}
鏈接:https://www.jb51.net/article/33171.htm
修改如下:
如下完整代碼::
1.創建id名為tdcag的DIV,內部為input輸入欄(添加聚焦/離焦事件),用來接收用戶輸入的數值,放在該td中
2.離焦時間中添加對應操作,最后一步innerHTML賦值,將生成的id名為tdcag的div覆蓋,顯示最終結果
用window獲得的td,會報錯跨域請求::解決方法:傳輸this獲得該td
onblur=fun();是觸發離焦事件
$("#txtId").unbind("input propertychange").bind("input propertychange",function(){......此處是監聽數值變動實時觸發})
如下修改調整為::數值改變可以實時觀看其他關聯數值變動
循環表格中某一td,得出總數如下::