"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
-
标题1
- 内容1
- 内容2
- 内容3
- 内容4
-
标题1_1
-
标题1_2
var tree = {
'标题2':[
'内容1',
'内容2',
'内容3',
'内容4',
{'标题2_1':['内容2_1','内容2_2','内容2_3','内容2_4']},
{'标题2_2':['内容2_1','内容2_2','内容2_3','内容2_4']},
'内容5'
]
}
var fragment = document.createElement('ul');
function concatTree(tree){
var array = [];
for(var key in tree){
array.push('
');
array.push(key);
array.push('
');
for(var i = 0; i < tree[key].length; i++){
if(tree[key][i].constructor == Object){
array = array.concat(concatTree(tree[key][i]));
}else{
array.push('- ');
array.push(tree[key][i]);
array.push(' ');
}
}
array.push('
');
}
return array;
}
fragment.innerHTML = concatTree(tree).join('');
$('outer_wrap').appendChild(fragment.firstChild);
var oArray = {
thead : ['标题一','标题二','标题三','标题四'],
tbody : [
[1,2,3,4],
[5,6,7,8],
[9,10,11,12],
[13,14,15,16],
[17,18,19,20],
[21,22,23,24]
],
tfoot : [25,26,27,28]
}
function createTable(arr){
var html = [];
html.push('
');
for(var key in arr){
html.push('<'+key + '>');
if(key == 'thead'){
assemTag(arr[key],html,'th')
}else if(key == 'tfoot'){
assemTag(arr[key],html,'td')
}else if(key == 'tbody'){
for(var k = 0, len_1 = arr[key].length; k < len_1; k++){
assemTag(arr[key][k],html,'td')
}
}
html.push(''+key + '>');
}
html.push('
');
var temp = document.createElement('div');
temp.innerHTML = html.join('');
return temp.firstChild;
}
function assemTag(array,html,tag){
html.push('
');
var s = '<' + tag + '>';
var e = '' + tag + '>';
for(var j = 0, len = array.length; j < len; j++){
html.push(s);
html.push(array[j]);
html.push(e);
}
html.push('
');
}
document.body.appendChild(createTable(oArray));
一般可以直接创建一个节点元素,然后直接设置innerHTML,不过innerHTML虽说是IE先搞起的,但是IE又最不彻底,对于table和tr是不可设置innerHTML的(只读),所以只能假div之手了。