메뉴 생성 클래스

· 20년 전 · 2617 · 1
<!--클래스-->
<script>
Layer = function() {
this.Elem = document.createElement('div');
this.Elem.id = 'Layer' + Layer.Count++;
this.Elem.appendChild(document.createElement('div'));
this.Elem.appendChild(document.createElement('div'));

// Properties
this.Id = this.Elem.id;
this.Drag = true;
this.Subject = 'Layer';
this.Content = 'Content';
this.Style = this.Elem.style;
this.SubjectStyle = this.Elem.children[0].style;
this.ContentStyle = this.Elem.children[1].style;
//

// Init
with(this.Style) {
position = 'absolute';
border = '1px solid slategray';
zIndex = Layer.ZIndex++;
}
with(this.SubjectStyle) {
font = 'bold 9pt tahoma';
backgroundColor = 'slategray';
color = 'lightgrey';
padding = '3px';
cursor = 'default';
}
with(this.ContentStyle) {
font = 'normal 9pt tahoma';
backgroundColor = 'whitesmoke';
color = 'slategray';
padding = '3px';
}
//

// Show Method
this.Show = function() {
document.body.appendChild(this.Elem);
this.Refresh();
}//

// Refresh Method
this.Refresh = function() {
this.Elem.children[1].innerHTML = this.Content;
with(this.Elem.children[0]) {
innerHTML = this.Subject;
onselectstart = function() { return false; }
style.width = Math.max(this.Elem.children[1].offsetWidth, offsetWidth);
ondblclick = function() {
with(this.parentElement.children[1].style) {
display = display ? '' : 'none';
}
}

// Drag Event
if(this.Drag) {
IsDrag = false;
var PadLeft = parseInt(style.paddingLeft);
var PadTop = parseInt(style.paddingTop);
onmousedown = function() {
IsDrag = true;
DragX = event.offsetX + PadLeft;
DragY = event.offsetY + PadTop;
}
onmouseup = function() { IsDrag = false; }
onmouseout = function() { IsDrag = false; }
onmousemove = function() {
if(IsDrag) {
with(this.parentElement.style) {
left = event.clientX - DragX;
top = event.clientY - DragY;
}
}
}
}
else {
IsDrag = DragX = DragY = null;
onmousedown = onmouseup = onmouseout = onmousemove = null;
}// End Drag Event
}

}// End Refresh()

// Event z-index
this.Elem.children[0].onclick = function() { this.parentElement.style.zIndex = Layer.ZIndex++; }
this.Elem.children[1].onclick = function() { this.parentElement.style.zIndex = Layer.ZIndex++; }
}
Layer.Count = 0;
Layer.ZIndex = 100;
</script>
<!---->

<!--사용-->
<script>
window.onload = function() {
with(document) {
with(body) {
Layer1 = new Layer();
Layer1.Subject = '드래그 ON 레이어';
Layer1.Content = '나 보기가 역겨워 가실때에는<br>' +
'말 없이 고이 보내 드리오리다.<br>' +
'<img src=http://mypds.mireene.com/g4/_v1/img/mybanner05.jpg>';
Layer1.Show();

Layer2 = new Layer();
Layer2.Style.left = '200px';
Layer2.SubjectStyle.color = 'red';
Layer2.Drag = false;
Layer2.Subject = '드래그 OFF 레이어';
Layer2.Content = '드래그 되지 않는 레이어<br>타이틀을 더블클릭하면 창이 축소됩니다.';
Layer2.Show();
Layer2.ContentStyle.backgroundColor = 'ivory';
Layer2.Refresh(); // Show() 호출 후 속성이 변경되면 Refresh() 호출
};
}
}
</script>
<!----><div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]</div>
|

댓글 1개

좋은팁 감사합니다.
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
19년 전 조회 4,074
19년 전 조회 3,260
19년 전 조회 4,105
19년 전 조회 3,454
19년 전 조회 3,078
19년 전 조회 3,375
19년 전 조회 2,421
19년 전 조회 2,826
19년 전 조회 2,323
19년 전 조회 3,688
19년 전 조회 4,721
19년 전 조회 3,753
19년 전 조회 1,712
19년 전 조회 2,722
19년 전 조회 2,364
19년 전 조회 2,603
19년 전 조회 4,387
19년 전 조회 2,560
19년 전 조회 3,011
19년 전 조회 2,973
19년 전 조회 3,643
19년 전 조회 3,600
19년 전 조회 1,822
19년 전 조회 2,192
19년 전 조회 2,754
19년 전 조회 2,418
19년 전 조회 4,287
19년 전 조회 3,280
19년 전 조회 4,060
19년 전 조회 2,576
19년 전 조회 2,460
19년 전 조회 2,929
19년 전 조회 2,458
19년 전 조회 2,757
19년 전 조회 2,442
19년 전 조회 3,151
19년 전 조회 1,669
19년 전 조회 2,968
19년 전 조회 2,234
19년 전 조회 2,161
19년 전 조회 2,256
19년 전 조회 2,609
19년 전 조회 2,093
19년 전 조회 4,441
19년 전 조회 2,653
19년 전 조회 2,432
19년 전 조회 2,937
20년 전 조회 3,031
20년 전 조회 3,088
20년 전 조회 2,618
20년 전 조회 2,995
20년 전 조회 2,522
20년 전 조회 2,182
20년 전 조회 2,765
20년 전 조회 2,452
20년 전 조회 2,524
20년 전 조회 3,779
20년 전 조회 3,253
20년 전 조회 4,970
20년 전 조회 2,394
20년 전 조회 4,486
20년 전 조회 3,085
20년 전 조회 2,862
20년 전 조회 3,708
20년 전 조회 2,624
20년 전 조회 3,705
20년 전 조회 3,978
20년 전 조회 3,405
20년 전 조회 3,454
20년 전 조회 4,073
20년 전 조회 2,328
20년 전 조회 5,064
20년 전 조회 3,621
20년 전 조회 2,569
20년 전 조회 2,251
20년 전 조회 2,709
20년 전 조회 2,997
20년 전 조회 2,766
bbbking
20년 전 조회 5,747
20년 전 조회 2,671
bbbking
20년 전 조회 4,249
20년 전 조회 2,119
20년 전 조회 7,280
20년 전 조회 2,384
20년 전 조회 3,459
20년 전 조회 4,269
20년 전 조회 2,590
20년 전 조회 3,878
20년 전 조회 3,041
20년 전 조회 4,069
20년 전 조회 5,094
20년 전 조회 4,201
20년 전 조회 5,818
20년 전 조회 2,021
20년 전 조회 3,281
20년 전 조회 3,512
20년 전 조회 2,898
20년 전 조회 2,410
20년 전 조회 4,637
20년 전 조회 2,245
🐛 버그신고