原生javaScript做得動(dòng)態(tài)表格(注釋寫(xiě)的很清楚)
更新時(shí)間:2013年12月29日 17:28:07 作者:
因?yàn)榭垂竞枚嘤脛?dòng)態(tài)表格的,所以,我就試著用js做了動(dòng)態(tài)表格,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下
最近看了3本o'reilly的書(shū),我們一般稱(chēng)為禽獸書(shū)(跟我一同學(xué)的名字很像大笑),然后一直想做一個(gè)列子來(lái)練練手,因?yàn)榭垂竞枚嘤脛?dòng)態(tài)表格的,所以,我就試著用js做了動(dòng)態(tài)表格,用firfox瀏覽器來(lái)調(diào)試的,因?yàn)閒irbug插件用著比較好,本來(lái)就是想實(shí)現(xiàn)一個(gè)很小的功能,沒(méi)想做那么多,就點(diǎn)擊按鈕能夠增加一行就行了,后來(lái)越加越多,也越來(lái)越好看了。把源碼貼出來(lái),大家共同學(xué)習(xí),有問(wèn)題也可以指正出來(lái),js初學(xué)者,忘大神筆下留情。
ps:不知道上面為什么不顯示行號(hào),好久沒(méi)用了。 注釋寫(xiě)的很清楚,大家共同學(xué)習(xí)。
<span style="font-size:18px;"><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>動(dòng)態(tài)表格</title>
<style type="text/css">
body{ background-color:#9CC; text-align:center}
table{ margin:10px auto;}
tr th { border: 1px solid #096;}
td{border: 1px solid #096;}
</style>
<script type="text/javascript">
/*在函數(shù)的外部只能聲明一些變量之類(lèi)的,不能用操作方法,因?yàn)闆](méi)有函數(shù)去調(diào)用執(zhí)行它。*/
//在載入頁(yè)面的時(shí)候就在表格頭放入選擇框,因?yàn)槭且淮涡缘?
window.onload = function(){
var tab = document.getElementById('tab');
var firsttr = document.getElementsByTagName('tr')[0];
var childtd = firsttr.childNodes;
//在第一行第一列上加入選擇框
var inp = document.createElement('input');
inp.type = 'checkbox';
//DOM Leve 2 事件注冊(cè)
catchEvent(inp,'click',function(){ //注冊(cè)函數(shù) 不同狀態(tài)進(jìn)行判斷
if(inp.checked ==true){
allSelect();
}else{
cancelSelect();
}
});
//catchEvent(inp,'click',allSelect);
//catchEvent(inp,'change',cancelSelect);
childtd[0].appendChild(inp);
}
//增加一行
//var count =0;//增加一列用來(lái) 計(jì)數(shù)
function addRow(){
//count++;
var tab = document.getElementById('tab');
var firsttr = document.getElementsByTagName('tr')[0];
var childtd = firsttr.childNodes;
var tr = document.createElement('tr');
var arrtd = new Array();
var arrinp = new Array();
for(var i =0;i<childtd.length;i++){
arrtd[i] = document.createElement('td');
arrinp[i] = document.createElement('input');
if(i==0){
arrinp[i].type = 'checkbox';
arrinp[i].name = 'selectbox';
}else if(i==1){
//arrinp[i] = document.createTextNode(count);
arrinp[i] = document.createTextNode('');
}
arrtd[i].appendChild(arrinp[i]);//思考為什么 input也要加上數(shù)組。
tr.appendChild(arrtd[i]);
}
tab.appendChild(tr);
newSort();
}
//刪除操作
function deleteRow(){
var parentTr = new Array();//先把被選中的行放在一個(gè)數(shù)組上
var box = document.getElementsByName('selectbox');
var tab = document.getElementById('tab');
for(var i = 0;i<box.length;i++){
if(box[i].checked==true){
var parent = box[i].parentNode;
parentTr[i] = parent.parentNode;//如果直接這種為放在里面為什么不能完全刪除??是因?yàn)榉磻?yīng)不夠嗎?
//tab.removeChild(parentTr);
}
}
for(var i = 0;i<parentTr.length;i++){ //這樣做才能把選中的全部刪除
if(parentTr[i]){ //這邊要先判斷一下是否為空值,如果不為空才去移除,否者會(huì)報(bào)錯(cuò)。
tab.removeChild(parentTr[i]);
}
}
newSort();
}
//如果執(zhí)行刪除的話(huà)則,重新進(jìn)行排序
function newSort(){
var text = new Array();
var child_td = new Array();
var arr_tr = document.getElementsByTagName('tr');
for(var i = 1;i<arr_tr.length;i++){
child_td[i] = arr_tr[i].childNodes[1];//獲得從第二行開(kāi)始所有第二列的節(jié)點(diǎn)
if(child_td[i].childNodes[0]){
child_td[i].removeChild(child_td[i].childNodes[0]);
}
text[i] = document.createTextNode(i);
child_td[i].appendChild(text[i]);
}
}
//全選操作
function allSelect(){
var box = document.getElementsByName('selectbox');
for(var i= 0;i<box.length;i++){
box[i].checked = true;
}
}
//全部取消選擇
function cancelSelect(){
var box = document.getElementsByName('selectbox');
for(var i = 0;i<box.length;i++){
if(box[i].checked == true){
box[i].checked =false;
}
}
}
//事件注冊(cè)函數(shù)
function catchEvent(eventobj,event,eventHandler){
if(eventobj.addEventListener){
eventobj.addEventListener(event,eventHandler,false);
}else if(eventobj.attachEvent){
event = 'on'+event;
eventobj.attachEvent(event,eventHandler);
}
}
//catchEvent(add,'click',addRow);
</script>
</head>
<body>
<h3>動(dòng)態(tài)表格</h3>
<input type="button" value="增加" id="add" onclick="addRow()" />
<input type="button" value="全部選擇" onclick="allSelect()" />
<input type="button" value="全部取消" onclick="cancelSelect()" />
<input type="button" value="刪除" id="delete" onclick="deleteRow()"/>
<table id="tab" cellpadding="5px" cellspacing="0px">
<tr><td></td><td>序號(hào)</td><td>題目一</td><td>題目二</td><td>題目三</td></tr>
</table>
</body>
</html></span>
ps:不知道上面為什么不顯示行號(hào),好久沒(méi)用了。 注釋寫(xiě)的很清楚,大家共同學(xué)習(xí)。
復(fù)制代碼 代碼如下:
<span style="font-size:18px;"><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>動(dòng)態(tài)表格</title>
<style type="text/css">
body{ background-color:#9CC; text-align:center}
table{ margin:10px auto;}
tr th { border: 1px solid #096;}
td{border: 1px solid #096;}
</style>
<script type="text/javascript">
/*在函數(shù)的外部只能聲明一些變量之類(lèi)的,不能用操作方法,因?yàn)闆](méi)有函數(shù)去調(diào)用執(zhí)行它。*/
//在載入頁(yè)面的時(shí)候就在表格頭放入選擇框,因?yàn)槭且淮涡缘?
window.onload = function(){
var tab = document.getElementById('tab');
var firsttr = document.getElementsByTagName('tr')[0];
var childtd = firsttr.childNodes;
//在第一行第一列上加入選擇框
var inp = document.createElement('input');
inp.type = 'checkbox';
//DOM Leve 2 事件注冊(cè)
catchEvent(inp,'click',function(){ //注冊(cè)函數(shù) 不同狀態(tài)進(jìn)行判斷
if(inp.checked ==true){
allSelect();
}else{
cancelSelect();
}
});
//catchEvent(inp,'click',allSelect);
//catchEvent(inp,'change',cancelSelect);
childtd[0].appendChild(inp);
}
//增加一行
//var count =0;//增加一列用來(lái) 計(jì)數(shù)
function addRow(){
//count++;
var tab = document.getElementById('tab');
var firsttr = document.getElementsByTagName('tr')[0];
var childtd = firsttr.childNodes;
var tr = document.createElement('tr');
var arrtd = new Array();
var arrinp = new Array();
for(var i =0;i<childtd.length;i++){
arrtd[i] = document.createElement('td');
arrinp[i] = document.createElement('input');
if(i==0){
arrinp[i].type = 'checkbox';
arrinp[i].name = 'selectbox';
}else if(i==1){
//arrinp[i] = document.createTextNode(count);
arrinp[i] = document.createTextNode('');
}
arrtd[i].appendChild(arrinp[i]);//思考為什么 input也要加上數(shù)組。
tr.appendChild(arrtd[i]);
}
tab.appendChild(tr);
newSort();
}
//刪除操作
function deleteRow(){
var parentTr = new Array();//先把被選中的行放在一個(gè)數(shù)組上
var box = document.getElementsByName('selectbox');
var tab = document.getElementById('tab');
for(var i = 0;i<box.length;i++){
if(box[i].checked==true){
var parent = box[i].parentNode;
parentTr[i] = parent.parentNode;//如果直接這種為放在里面為什么不能完全刪除??是因?yàn)榉磻?yīng)不夠嗎?
//tab.removeChild(parentTr);
}
}
for(var i = 0;i<parentTr.length;i++){ //這樣做才能把選中的全部刪除
if(parentTr[i]){ //這邊要先判斷一下是否為空值,如果不為空才去移除,否者會(huì)報(bào)錯(cuò)。
tab.removeChild(parentTr[i]);
}
}
newSort();
}
//如果執(zhí)行刪除的話(huà)則,重新進(jìn)行排序
function newSort(){
var text = new Array();
var child_td = new Array();
var arr_tr = document.getElementsByTagName('tr');
for(var i = 1;i<arr_tr.length;i++){
child_td[i] = arr_tr[i].childNodes[1];//獲得從第二行開(kāi)始所有第二列的節(jié)點(diǎn)
if(child_td[i].childNodes[0]){
child_td[i].removeChild(child_td[i].childNodes[0]);
}
text[i] = document.createTextNode(i);
child_td[i].appendChild(text[i]);
}
}
//全選操作
function allSelect(){
var box = document.getElementsByName('selectbox');
for(var i= 0;i<box.length;i++){
box[i].checked = true;
}
}
//全部取消選擇
function cancelSelect(){
var box = document.getElementsByName('selectbox');
for(var i = 0;i<box.length;i++){
if(box[i].checked == true){
box[i].checked =false;
}
}
}
//事件注冊(cè)函數(shù)
function catchEvent(eventobj,event,eventHandler){
if(eventobj.addEventListener){
eventobj.addEventListener(event,eventHandler,false);
}else if(eventobj.attachEvent){
event = 'on'+event;
eventobj.attachEvent(event,eventHandler);
}
}
//catchEvent(add,'click',addRow);
</script>
</head>
<body>
<h3>動(dòng)態(tài)表格</h3>
<input type="button" value="增加" id="add" onclick="addRow()" />
<input type="button" value="全部選擇" onclick="allSelect()" />
<input type="button" value="全部取消" onclick="cancelSelect()" />
<input type="button" value="刪除" id="delete" onclick="deleteRow()"/>
<table id="tab" cellpadding="5px" cellspacing="0px">
<tr><td></td><td>序號(hào)</td><td>題目一</td><td>題目二</td><td>題目三</td></tr>
</table>
</body>
</html></span>
您可能感興趣的文章:
- js生成動(dòng)態(tài)表格并為每個(gè)單元格添加單擊事件的方法
- JS實(shí)現(xiàn)動(dòng)態(tài)表格的添加,修改,刪除功能(推薦)
- JavaScript實(shí)現(xiàn)簡(jiǎn)單動(dòng)態(tài)表格
- JavaScript實(shí)現(xiàn)動(dòng)態(tài)表格效果
- JavaScript實(shí)現(xiàn)動(dòng)態(tài)表格的方法詳解
- JavaScript實(shí)現(xiàn)生成動(dòng)態(tài)表格和動(dòng)態(tài)效果的方法詳解
- java前端javascript生成動(dòng)態(tài)表格示例演示
- JavaScript實(shí)現(xiàn)動(dòng)態(tài)表格的示例代碼
相關(guān)文章
Web開(kāi)發(fā)中使用SVG圖標(biāo)的7種方法舉例總結(jié)
這篇文章主要介紹了7種嵌入SVG圖標(biāo)的方法,包括內(nèi)聯(lián)SVG、img標(biāo)簽、object標(biāo)簽、CSS背景圖像、SVG圖標(biāo)字體、use元素和JavaScript動(dòng)態(tài)加載,每種方法都有其優(yōu)勢(shì)和限制,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-03-03
利用JavaScript實(shí)現(xiàn)靜態(tài)圖片局部流動(dòng)效果
如果你有玩過(guò)《王者榮耀》、《陰陽(yáng)師》?等手游,一定注意到過(guò)它的啟動(dòng)動(dòng)畫(huà)、皮膚立繪卡片等場(chǎng)景,經(jīng)常采用靜態(tài)底圖加局部液態(tài)流動(dòng)效果的簡(jiǎn)單動(dòng)畫(huà),本文將利用JavaScript實(shí)現(xiàn)這一效果,需要的可以參考一下2022-08-08
web3.js調(diào)用鏈上的方法操作NFT區(qū)塊鏈MetaMask詳解
這篇文章主要為大家介紹了web3.js調(diào)用鏈上的方法操作NFT區(qū)塊鏈MetaMask詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
wap手機(jī)圖片滑動(dòng)切換特效無(wú)css3元素js腳本編寫(xiě)
手機(jī)圖片滑動(dòng)切換,網(wǎng)上有很多這樣的例子,但都借助于其他組件,讓代碼混亂的不行,本例無(wú)css3元素js腳本編寫(xiě),需要的朋友可以參考下2014-07-07
js eval函數(shù)使用,js對(duì)象和字符串互轉(zhuǎn)實(shí)例
下面小編就為大家?guī)?lái)一篇js eval函數(shù)使用,js對(duì)象和字符串互轉(zhuǎn)實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03

