使html表格可编辑状态,js+Html实现表格可编辑操作
本文實例為大家分享了js+Html實現表格可編輯操作的具體代碼,供大家參考,具體內容如下
功能描述:單擊頁面使單元格td變成可編輯狀態,輸入內容后,當單元格失去焦點時,保存輸入的內容。
點擊增加行,在table的末尾增加一行;點擊刪除行,刪除table中最末尾的一行。
編輯表格數據/**
* JS實現可編輯的表格
* 用法:EditTables(tb1,tb2,tb2,......);
**/
//設置多個表格可編輯
function EditTables(){
for(var i=0;i
SetTableCanEdit(arguments[i]);
}
}
//設置表格是可編輯的
function SetTableCanEdit(table){
for(var i=1; i
SetRowCanEdit(table.rows[i]);
}
}
function SetRowCanEdit(row){
for(var j=0;j
//如果當前單元格指定了編輯類型,則表示允許編輯
var editType = row.cells[j].getAttribute("EditType");
if(!editType){
//如果當前單元格沒有指定,則查看當前列是否指定
editType = row.parentNode.rows[0].cells[j].getAttribute("EditType");
}
if(editType){
row.cells[j].onclick = function (){
EditCell(this);
}
}
}
}
//設置指定單元格可編輯
function EditCell(element, editType){
var editType = element.getAttribute("EditType");
if(!editType){
//如果當前單元格沒有指定,則查看當前列是否指定
editType = element.parentNode.parentNode.rows[0].cells[element.cellIndex].getAttribute("EditType");
}
switch(editType){
case "TextBox":
CreateTextBox(element, element.innerHTML);
break;
case "DropDownList":
CreateDropDownList(element);
break;
default:
break;
}
}
//為單元格創建可編輯輸入框
function CreateTextBox(element, value){
//檢查編輯狀態,如果已經是編輯狀態,跳過
var editState = element.getAttribute("EditState");
if(editState != "true"){
//創建文本框
var textBox = document.createElement("INPUT");
textBox.type = "text";
textBox.className="EditCell_TextBox";
//設置文本框當前值
if(!value){
value = element.getAttribute("Value");
}
textBox.value = value;
//設置文本框的失去焦點事件
textBox.onblur = function (){
CancelEditCell(this.parentNode, this.value);
}
//向當前單元格添加文本框
ClearChild(element);
element.appendChild(textBox);
textBox.focus();
textBox.select();
//改變狀態變量
element.setAttribute("EditState", "true");
element.parentNode.parentNode.setAttribute("CurrentRow", element.parentNode.rowIndex);
}
}
//為單元格創建選擇框
function CreateDropDownList(element, value){
//檢查編輯狀態,如果已經是編輯狀態,跳過
var editState = element.getAttribute("EditState");
if(editState != "true"){
//創建下接框
var downList = document.createElement("Select");
downList.className="EditCell_DropDownList";
//添加列表項
var items = element.getAttribute("DataItems");
if(!items){
items = element.parentNode.parentNode.rows[0].cells[element.cellIndex].getAttribute("DataItems");
}
if(items){
items = eval("[" + items + "]");
for(var i=0; i
var oOption = document.createElement("OPTION");
oOption.text = items[i].text;
oOption.value = items[i].value;
downList.options.add(oOption);
}
}
//設置列表當前值
if(!value){
value = element.getAttribute("Value");
}
downList.value = value;
//設置創建下接框的失去焦點事件
downList.onblur = function (){
CancelEditCell(this.parentNode, this.value, this.options[this.selectedIndex].text);
}
//向當前單元格添加創建下接框
ClearChild(element);
element.appendChild(downList);
downList.focus();
//記錄狀態的改變
element.setAttribute("EditState", "true");
element.parentNode.parentNode.setAttribute("LastEditRow", element.parentNode.rowIndex);
}
}
//取消單元格編輯狀態
function CancelEditCell(element, value, text){
element.setAttribute("Value", value);
if(text){
element.innerHTML = text;
}else{
element.innerHTML = value;
}
element.setAttribute("EditState", "false");
//檢查是否有公式計算
CheckExpression(element.parentNode);
}
//清空指定對象的所有字節點
function ClearChild(element){
element.innerHTML = "";
}
//添加行
function AddRow(table, index){
var lastRow = table.rows[table.rows.length-1];
var newRow = lastRow.cloneNode(true);
//計算新增加行的序號,需要引入jquery 的jar包
var startIndex = $.inArray(lastRow,table.rows);
var endIndex = table.rows;
table.tBodies[0].appendChild(newRow);
newRow.cells[0].innerHTML=endIndex-startIndex;
SetRowCanEdit(newRow);
return newRow;
}
//刪除行
function DeleteRow(table, index){
for(var i=table.rows.length - 1; i>0;i--){
var chkOrder = table.rows[i].cells[0].firstChild;
if(chkOrder){
if(chkOrder.type = "CHECKBOX"){
if(chkOrder.checked){
//執行刪除
table.deleteRow(i);
}
}
}
}
}
//提取表格的值,JSON格式
function GetTableData(table){
var tableData = new Array();
alert("行數:" + table.rows.length);
for(var i=1; i
tableData.push(GetRowData(tabProduct.rows[i]));
}
return tableData;
}
//提取指定行的數據,JSON格式
function GetRowData(row){
var rowData = {};
for(var j=0;j
name = row.parentNode.rows[0].cells[j].getAttribute("Name");
if(name){
var value = row.cells[j].getAttribute("Value");
if(!value){
value = row.cells[j].innerHTML;
}
rowData[name] = value;
}
}
//alert("ProductName:" + rowData.ProductName);
//或者這樣:alert("ProductName:" + rowData["ProductName"]);
return rowData;
}
//檢查當前數據行中需要運行的字段
function CheckExpression(row){
for(var j=0;j
expn = row.parentNode.rows[0].cells[j].getAttribute("Expression");
//如指定了公式則要求計算
if(expn){
var result = Expression(row,expn);
var format = row.parentNode.rows[0].cells[j].getAttribute("Format");
if(format){
//如指定了格式,進行字值格式化
row.cells[j].innerHTML = formatNumber(Expression(row,expn), format);
}else{
row.cells[j].innerHTML = Expression(row,expn);
}
}
}
}
//計算需要運算的字段
function Expression(row, expn){
var rowData = GetRowData(row);
//循環代值計算
for(var j=0;j
name = row.parentNode.rows[0].cells[j].getAttribute("Name");
if(name){
var reg = new RegExp(name, "i");
expn = expn.replace(reg, rowData[name].replace(/\,/g, ""));
}
}
return eval(expn);
}
///
/**
* 格式化數字顯示方式
* 用法
* formatNumber(12345.999,'#,##0.00');
* formatNumber(12345.999,'#,##0.##');
* formatNumber(123,'000000');
* @param num
* @param pattern
*/
/* 以下是范例
formatNumber('','')=0
formatNumber(123456789012.129,null)=123456789012
formatNumber(null,null)=0
formatNumber(123456789012.129,'#,##0.00')=123,456,789,012.12
formatNumber(123456789012.129,'#,##0.##')=123,456,789,012.12
formatNumber(123456789012.129,'#0.00')=123,456,789,012.12
formatNumber(123456789012.129,'#0.##')=123,456,789,012.12
formatNumber(12.129,'0.00')=12.12
formatNumber(12.129,'0.##')=12.12
formatNumber(12,'00000')=00012
formatNumber(12,'#.##')=12
formatNumber(12,'#.00')=12.00
formatNumber(0,'#.##')=0
*/
function formatNumber(num,pattern){
var strarr = num?num.toString().split('.'):['0'];
var fmtarr = pattern?pattern.split('.'):[''];
var retstr='';
// 整數部分
var str = strarr[0];
var fmt = fmtarr[0];
var i = str.length-1;
var comma = false;
for(var f=fmt.length-1;f>=0;f--){
switch(fmt.substr(f,1)){
case '#':
if(i>=0 ) retstr = str.substr(i--,1) + retstr;
break;
case '0':
if(i>=0) retstr = str.substr(i--,1) + retstr;
else retstr = '0' + retstr;
break;
case ',':
comma = true;
retstr=','+retstr;
break;
}
}
if(i>=0){
if(comma){
var l = str.length;
for(;i>=0;i--){
retstr = str.substr(i,1) + retstr;
if(i>0 && ((l-i)%3)==0) retstr = ',' + retstr;
}
}
else retstr = str.substr(0,i+1) + retstr;
}
retstr = retstr+'.';
// 處理小數部分
str=strarr.length>1?strarr[1]:'';
fmt=fmtarr.length>1?fmtarr[1]:'';
i=0;
for(var f=0;f
switch(fmt.substr(f,1)){
case '#':
if(i
break;
case '0':
if(i
else retstr+='0';
break;
}
}
return retstr.replace(/^,+/,'').replace(/\.$/,'');
}
可編輯的表格
| 序號 | 商品名稱 | 數量 | 單價 | 合計 | |
| 1 | C | 0 | 0 | 0 | |
| 2 | D | 0 | 0 | 0 |
var tabProduct = document.getElementById("tabProduct");
// 設置表格可編輯
// 可一次設置多個,例如:EditTables(tb1,tb2,tb2,......)
EditTables(tabProduct);
效果如下:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
總結
以上是生活随笔為你收集整理的使html表格可编辑状态,js+Html实现表格可编辑操作的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java map用二叉树_【课堂笔记分享
- 下一篇: python 爬虫代理_python 爬