COMING SOON 🚀

엑셀 흉내내기

· 10년 전 · 1462

<style>

#excel {width: 800px; height: 400px; overflow: auto; border: 1px solid #ccc}

#excel table { width: 2000px; border-spacing:0 }

#excel table th {font-weight: normal; background-color: #eee}

#excel table th, #excel table  td { height: 20px; border: 1px solid #ddd; }

#excel table td {text-align: right; padding: 0; }

#excel table input {border:none; border-right:0px; border-top:0px; boder-left:0px; boder-bottom:0px; outline-style: none; font-size:  1em }

</style>

<div id="excel"></div>

<script>

function Excel(label, rows, cols) {

this.div = document.getElementById(label);

this.table = document.createElement('table');

this.rows = rows;

this.cols = cols;

this.clicked = null;

this.cells = [];

}

Excel.prototype.init = function() {

var tr = {}, el = {}, r = 0, c = 0, tr = document.createElement('tr')

for (c=0;  c<this.cols; c++) {

el = document.createElement('th');

el.style.width = Math.round(100 / this.cols * 10) / 10 + '%'; 

if (c != 0) el.textContent = String.fromCharCode(64 + c);

tr.appendChild(el);

}

this.table.appendChild(tr);

for (r=1;  r<this.rows; r++) {

tr = document.createElement('tr');

for (c=0;  c<this.cols; c++) {

if (c !=0) el= document.createElement('td');

else {

el= document.createElement('th');

el.textContent = r;

}

tr.appendChild(el);

}

this.table.appendChild(tr);

}

this.div.appendChild(this.table);

};

Excel.prototype.getPos = function(obj) {

var pos = {};

pos.r = obj.parentNode.rowIndex;

pos.c = obj.cellIndex;

return pos;

}

Excel.prototype.click = function() {

var td = this, textbox, text, pos = excel.getPos(this);

if (excel.clicked != null) excel.clicked.style.border = '1px solid #ddd';

this.style.border = '1px solid blue';

excel.clicked = this;

textbox = document.createElement('input');

if (this.hasChildNodes()) {

if (this.firstChild.nodeName == 'INPUT') return;

else {

text = this.firstChild.textContent; 

textbox.value = excel.cells[pos.r + ',' + pos.c];

this.removeChild(this.firstChild);

}

}

textbox.type = 'text'; 

textbox.style.width = (this.offsetWidth - 2) + 'px';

textbox.style.height = (this.offsetHeight - 4) + 'px';

this.appendChild(textbox);

this.firstChild.focus();

textbox.onblur = function(){  

text = this.value;

this.remove(0);

excel.cells[pos.r + ',' + pos.c] = text; 

if (text.match(/^=/)) text = eval( text.replace('=', '') );

td.textContent = text;

}; 

}

Excel.prototype.edit = function() {

var table, tr = {}, el = {}, r = 0, c = 0,

table = this.div.childNodes[0];

for (r=1; r<this.rows; r++) {

for (c=1; c<this.cols; c++) { 

el = table.rows[r].cells[c];

el.onclick  = this.click;

el.onkeydown = this.keydown;

}

}

};

Excel.prototype.keydown = function(e) {

var pos = excel.getPos(this), e = e || window.event;

switch (e.keyCode) {

case 38 : pos.r -= 1; break;

case 40 : case 13: pos.r += 1; break;

case 37 : pos.c -= 1; break;

case 39 : pos.c += 1; break;

}

if (pos.r < 1 || pos.r > excel.rows-1 || pos.c < 1 || pos.c > excel.cols-1) return;

excel.table.rows[pos.r].cells[pos.c].click();

};

var excel = new Excel('excel', 40, 27);

excel.init();

excel.edit();

</script>

|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
10년 전 조회 1,128
10년 전 조회 1,155
10년 전 조회 1,149
10년 전 조회 1,196
10년 전 조회 1,300
10년 전 조회 1,382
10년 전 조회 1,176
10년 전 조회 1,242
10년 전 조회 1,130
10년 전 조회 1,048
10년 전 조회 1,101
10년 전 조회 1,235
10년 전 조회 1,129
10년 전 조회 1,147
10년 전 조회 1,137
10년 전 조회 1,271
10년 전 조회 1,258
10년 전 조회 1,774
10년 전 조회 1,164
10년 전 조회 1,267
10년 전 조회 1,158
10년 전 조회 1,487
10년 전 조회 1,206
10년 전 조회 1,188
10년 전 조회 1,114
10년 전 조회 1,107
10년 전 조회 1,405
10년 전 조회 1,296
10년 전 조회 1,104
10년 전 조회 1,221
10년 전 조회 1,375
10년 전 조회 1,091
10년 전 조회 1,153
10년 전 조회 1,109
10년 전 조회 1,569
10년 전 조회 1,268
10년 전 조회 1,296
10년 전 조회 1,207
10년 전 조회 1,333
10년 전 조회 1,537
10년 전 조회 1,417
10년 전 조회 1,354
10년 전 조회 1,308
10년 전 조회 1,335
10년 전 조회 1,311
10년 전 조회 1,259
10년 전 조회 1,724
10년 전 조회 1,242
10년 전 조회 1,242
10년 전 조회 1,463
10년 전 조회 1,261
10년 전 조회 1,297
10년 전 조회 1,133
10년 전 조회 1,396
10년 전 조회 1,227
10년 전 조회 1,147
10년 전 조회 1,204
10년 전 조회 1,883
10년 전 조회 1,223
10년 전 조회 1,233
10년 전 조회 1,234
10년 전 조회 1,350
10년 전 조회 1,830
10년 전 조회 1,419
10년 전 조회 1,241
10년 전 조회 1,179
10년 전 조회 1,213
10년 전 조회 1,308
10년 전 조회 1,211
10년 전 조회 1,288
10년 전 조회 1,200
10년 전 조회 1,372
10년 전 조회 1,225
10년 전 조회 1,198
10년 전 조회 1,142
10년 전 조회 1,791
10년 전 조회 1,289
10년 전 조회 1,207
10년 전 조회 1,251
10년 전 조회 1,233
10년 전 조회 1,250
10년 전 조회 1,225
10년 전 조회 1,730
10년 전 조회 1,176
10년 전 조회 1,263
10년 전 조회 1,138
10년 전 조회 1,715
10년 전 조회 1,304
10년 전 조회 1,311
10년 전 조회 1,354
10년 전 조회 1,296
10년 전 조회 1,298
10년 전 조회 1,242
10년 전 조회 1,134
10년 전 조회 1,258
10년 전 조회 1,131
10년 전 조회 1,465
10년 전 조회 1,185
10년 전 조회 1,203
10년 전 조회 1,182