메뉴 생성 클래스
<!--클래스-->
<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>
<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개
pearly
19년 전
좋은팁 감사합니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 8511 |
JavaScript
아파치 로그 정리(압축) logrotate
|
| 8510 |
MySQL
아파치와 mysql 자동실행 시키는 방법..
|
| 8509 | |
| 8506 |
PHP
아파치 무단링크 막기
2
|
| 8505 | |
| 8503 | |
| 8502 | |
| 8497 | |
| 8492 | |
| 8491 | |
| 8490 | |
| 8489 |
JavaScript
불여우에서도 되는 메뉴 2
|
| 8487 | |
| 8484 | |
| 8483 | |
| 8482 | |
| 28459 | |
| 8481 | |
| 8478 | |
| 8477 | |
| 8475 | |
| 8474 | |
| 8473 | |
| 8472 |
JavaScript
RH7.3 설치후 해주어야 할것들
|
| 8471 | |
| 8469 | |
| 8468 | |
| 8467 | |
| 8466 | |
| 8465 |
JavaScript
원하는 사람에게 메일 보내기 버튼 만들기
|
| 8464 | |
| 8463 | |
| 8462 | |
| 8461 | |
| 8460 |
JavaScript
전송버튼에 '전송중...' 이라는 표시를 해 줍니다
|
| 8459 | |
| 8458 | |
| 8457 | |
| 8456 |
JavaScript
텍스트 필드에 디폴트 메세지를 보여주고 클릭하면 사라집니다
|
| 8455 |
JavaScript
특정일(ex 30일)이 지난 파일 삭제 및 디렉토리 이동하기
|
| 8452 |
MySQL
cron [퍼옮]
2
|
| 8451 |
MySQL
mysql에서의 subquery
|
| 8449 |
MySQL
여러데이터베이스 사용하는 방법 - 퍼옮
1
|
| 28458 |
HTML
문자열 연결 CONCAT()
|
| 8445 | |
| 8444 |
MySQL
패스워드 변경 및 루트 패스워드 찾기
|
| 8443 |
MySQL
MySQL 설치
|
| 8442 | |
| 8441 |
MySQL
MySQL 컬럼 형 [퍼옮]
|
| 8440 | |
| 8439 |
MySQL
MySQL 내부연산 ( 비교연산 )
|
| 8438 | |
| 8437 |
MySQL
MySQL 함수정리 ( 수학함수 ) [퍼옮]
|
| 8436 |
JavaScript
GROUP BY 와 같이 사용되는 함수 [퍼옮]
|
| 8435 |
MySQL
MySQL 문자열 관련함수[퍼옮]
|
| 8433 |
MySQL
MySQL 날짜 관련 함수[퍼옮]
1
|
| 8428 | |
| 8427 | |
| 8426 |
MySQL
MySql 기본명령어 모음[콘솔사용시]
|
| 28456 | |
| 8425 |
JavaScript
유효 도메인 책크하기
|
| 8424 | |
| 8423 | |
| 8422 | |
| 8421 |
기타
파일 관련함수 [퍼옮]
|
| 8419 | |
| 8418 | |
| 8417 |
PHP
미리 정의된 변수들 [퍼옮]
|
| 28455 |
HTML
디렉토리 관련함수 [퍼옮]
|
| 8416 |
MySQL
문자열 함수 - 퍼 옮 -
|
| 8415 |
JavaScript
배열함수
|
| 8414 | |
| 8412 |
JavaScript
mktime()
1
|
| 28454 |
HTML
setcookie
|
| 8411 |
PHP
array_rand()
|
| 28451 |
HTML
eregi() vs ereg()
2
|
| 8410 |
JavaScript
strrchr()
|
| 8409 |
기타
key()
|
| 8406 |
JavaScript
GetImageSize()
2
|
| 8405 |
JavaScript
리눅스 서버의 시간이 맞지 않을때?
|
| 28450 |
HTML
man 페이지 txt파일로 저장하기
|
| 8404 | |
| 8403 |
기타
이동식 메뉴 박스
|
| 8402 | |
| 8401 | |
| 8400 |
JavaScript
체크박스를 클릭하면 이동하는 체크박스 메뉴 스크립트
|
| 8399 | |
| 8391 | |
| 8390 | |
| 8389 |
JavaScript
디렉토리 내에서 파일만 퍼미션 변경
|
| 8387 | |
| 28447 |
HTML
이미지를 5단계로 키워서 보자
2
|
| 8386 |
JavaScript
DirectX의 와이프 기능을 사용한 이미지 스와핑 효과
|
| 8384 | |
| 8382 |
JavaScript
특정 이미지를 지정한 날까지만 보여줍니다
1
|
| 8380 | |
| 8379 | |
| 8377 |
JavaScript
iframe 써서 노 프레임 효과 내기
1
|
| 8376 | |
| 8375 |
MySQL
[펌] mysql 인덱싱.
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기