[Javascript] Internet Explorer에서 Prototype을 이용한 동적으로 table생성시 문제점.
자바스크립트(Javascript) 2008. 7. 8. 19:26한 1주일 고생했습니다.
IE에서는 왜 동적으로 테이블을 생성하면 안나오지?-_-;
[code]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Insert Test</title>
<script src="lib/prototype/prototype.js" type="text/javascript">
</script>
<script>
function init(){
var table = new Element('table', {border: 1});
for (var i = 0; i < 5; i++) {
var tr = new Element('tr');
for (var j = 0; j < 5; j++) {
var td = new Element('td');
td.update((i*8+j) + '번');
tr.insert(td);
}
table.insert(tr);
}
$('div').insert(table);
}
</script>
</head>
<body onload="init();">
<div id="div"></div>
</body>
</html>
[/code]
이렇게 하면 FF(FireFox)에서는 잘 나오는데, IE에서는 보이지 않습니다.
웃긴건 IE에서 div.innerHTML을 alert으로 찍어봐도 테이블 태그가 잘 나옵니다.
신기하게 이걸 tbody태그로 한번 감싸주면 잘 됩니다.
[code]
<script>
function init(){
var table = new Element('table', {border: 1});
var tbody = new Element('tbody');
for (var i = 0; i < 5; i++) {
var tr = new Element('tr');
for (var j = 0; j < 5; j++) {
var td = new Element('td');
td.update((i*8+j) + '번');
tr.insert(td);
}
tbody.insert(tr);
}
table.insert(tbody);
$('div').insert(table);
}
</script>
[/code]
이렇게 tbody로 한번 감싸주면 잘 나옵니다.
tbody용도는
http://www.sunslife.com/bbs/view.php?id=2002&no=1620
이 사이트에서 확인할 수 있습니다.
thead, tfoot, tbody 테이블을 세단계로 나눌 때 사용하는건데...왜 저걸 하면 IE에서는 보이는거지?-_-;
IE에서는 왜 동적으로 테이블을 생성하면 안나오지?-_-;
[code]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Insert Test</title>
<script src="lib/prototype/prototype.js" type="text/javascript">
</script>
<script>
function init(){
var table = new Element('table', {border: 1});
for (var i = 0; i < 5; i++) {
var tr = new Element('tr');
for (var j = 0; j < 5; j++) {
var td = new Element('td');
td.update((i*8+j) + '번');
tr.insert(td);
}
table.insert(tr);
}
$('div').insert(table);
}
</script>
</head>
<body onload="init();">
<div id="div"></div>
</body>
</html>
[/code]
이렇게 하면 FF(FireFox)에서는 잘 나오는데, IE에서는 보이지 않습니다.
웃긴건 IE에서 div.innerHTML을 alert으로 찍어봐도 테이블 태그가 잘 나옵니다.
신기하게 이걸 tbody태그로 한번 감싸주면 잘 됩니다.
[code]
<script>
function init(){
var table = new Element('table', {border: 1});
var tbody = new Element('tbody');
for (var i = 0; i < 5; i++) {
var tr = new Element('tr');
for (var j = 0; j < 5; j++) {
var td = new Element('td');
td.update((i*8+j) + '번');
tr.insert(td);
}
tbody.insert(tr);
}
table.insert(tbody);
$('div').insert(table);
}
</script>
[/code]
이렇게 tbody로 한번 감싸주면 잘 나옵니다.
tbody용도는
http://www.sunslife.com/bbs/view.php?id=2002&no=1620
이 사이트에서 확인할 수 있습니다.
thead, tfoot, tbody 테이블을 세단계로 나눌 때 사용하는건데...왜 저걸 하면 IE에서는 보이는거지?-_-;