자동 스크롤 메뉴 (끄기 기능)

<script language="javascript">
<!--

var stmnLEFT = 10; // 스크롤메뉴의 좌측 위치
var stmnGAP1 = 10; // 페이지 헤더부분의 여백
var stmnGAP2 = 200; // 스크롤시 브라우저 상단과 약간 띄움. 필요없으면 0으로 세팅
var stmnBASE = 100; // 스크롤메뉴 초기 시작위치 (아무렇게나 해도 상관은 없지만 stmnGAP1과 약간 차이를 주는게 보기 좋음)
var stmnActivateSpeed = 0; // 움직임을 감지하는 속도 (숫자가 클수록 늦게 알아차림)
var stmnScrollSpeed = 0; // 스크롤되는 속도 (클수록 늦게 움직임)

var stmnTimer;

function ReadCookie(name) {
var label = name + "=";
var labelLen = label.length;
var cLen = document.cookie.length;
var i = 0;

while (i < cLen) {
var j = i + labelLen;

if (document.cookie.substring(i, j) == label) {
var cEnd = document.cookie.indexOf(";", j);
if (cEnd == -1) cEnd = document.cookie.length;
return unescape(document.cookie.substring(j, cEnd));
}
i++;
}
return "";
}

function SaveCookie(name, value, expire) {
var eDate = new Date();
eDate.setDate(eDate.getDate() + expire);
document.cookie = name + "=" + value + "; expires=" + eDate.toGMTString()+ "; path=/";
}

function RefreshStaticMenu()
{
var stmnStartPoint, stmnEndPoint, stmnRefreshTimer;

stmnStartPoint = parseInt(STATICMENU.style.top, 10);


stmnEndPoint = document.body.scrollTop + stmnGAP2;

stmnLimit = parseInt(window.document.body.scrollHeight) - parseInt(STATICMENU.offsetHeight);
if (stmnEndPoint > stmnLimit) stmnEndPoint = stmnLimit;

if (stmnEndPoint < stmnGAP1) stmnEndPoint = stmnGAP1;

stmnRefreshTimer = stmnActivateSpeed;

if ( stmnStartPoint != stmnEndPoint ) {
stmnScrollAmount = Math.ceil( Math.abs( stmnEndPoint - stmnStartPoint ) / 15 );
STATICMENU.style.top = parseInt(STATICMENU.style.top, 10) + ( ( stmnEndPoint<stmnStartPoint ) ? -stmnScrollAmount : stmnScrollAmount );
stmnRefreshTimer = stmnScrollSpeed;
}

stmnTimer = setTimeout ("RefreshStaticMenu();", stmnRefreshTimer);
}

function ToggleAnimate() {
if (!ANIMATE.checked) {
RefreshStaticMenu();
SaveCookie("ANIMATE", "true", 300);
} else {
clearTimeout(stmnTimer);
STATICMENU.style.top = stmnGAP1;
SaveCookie("ANIMATE", "false", 300);
}
}

function InitializeStaticMenu() {
STATICMENU.style.left = stmnLEFT;
if (ReadCookie("ANIMATE") == "false") {
ANIMATE.checked = true;
STATICMENU.style.top = document.body.scrollTop + stmnGAP1;
} else {
ANIMATE.checked = false;
STATICMENU.style.top = document.body.scrollTop + stmnBASE;
RefreshStaticMenu();
}
}
//-->
</script>



<div id="STATICMENU" style="position:absolute;width:150px;height:120px;">
<table border="0" cellspacing="0" cellpadding="0" width="100%" height="100%" style="border:1 solid #999999;">
<tr>
<td align="center" height="100">


이곳에 메뉴를 넣어주세요.


</td>
</tr>
<tr>
<td align="left" height="20"> <input id="ANIMATE" type="checkbox" onclick="ToggleAnimate();"> 따라다님 끄기</td>
</tr>
</table>
</div>

<script language="javascript">
<!--
InitializeStaticMenu(); // 스크롤메뉴를 가동하는 자바스크립트
//-->
</script>




<br> <!--연습장용 -_-; (스크롤바를 생기게 하려면..)--!>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>


ㅡㅡ;<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]</div>
|

댓글 2개

좋은 소스 올려 주셔서 감사합니다....^^
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
19년 전 조회 1,718
19년 전 조회 2,309
19년 전 조회 3,949
19년 전 조회 3,727
19년 전 조회 3,447
19년 전 조회 3,400
19년 전 조회 1,560
19년 전 조회 1,929
19년 전 조회 1,851
19년 전 조회 2,518
19년 전 조회 4,614
19년 전 조회 2,750
19년 전 조회 1,915
19년 전 조회 1,924
19년 전 조회 1,812
19년 전 조회 2,552
19년 전 조회 8,172
19년 전 조회 2,720
19년 전 조회 2,785
19년 전 조회 3,037
19년 전 조회 2,193
19년 전 조회 2,207
19년 전 조회 2,171
19년 전 조회 2,064
19년 전 조회 2,254
19년 전 조회 2,511
19년 전 조회 3,076
19년 전 조회 2,328
19년 전 조회 1,903
19년 전 조회 2,828
19년 전 조회 4,994
19년 전 조회 3,492
19년 전 조회 3,450
19년 전 조회 2,971
19년 전 조회 2,394
19년 전 조회 1,484
19년 전 조회 3,132
19년 전 조회 2,006
19년 전 조회 5,368
19년 전 조회 2,426
19년 전 조회 3,427
19년 전 조회 2,851
19년 전 조회 1,759
19년 전 조회 3,876
19년 전 조회 2,413
19년 전 조회 2,294
19년 전 조회 3,017
19년 전 조회 3,292
19년 전 조회 2,493
19년 전 조회 2,259
19년 전 조회 2,324
19년 전 조회 1,993
19년 전 조회 3,085
19년 전 조회 2,010
19년 전 조회 2,044
19년 전 조회 1,697
19년 전 조회 2,206
19년 전 조회 2,184
19년 전 조회 2,478
19년 전 조회 2,872
19년 전 조회 2,382
19년 전 조회 2,450
19년 전 조회 3,501
19년 전 조회 3,212
19년 전 조회 3,204
19년 전 조회 3,009
19년 전 조회 2,027
19년 전 조회 2,338
19년 전 조회 2,228
19년 전 조회 2,056
19년 전 조회 2,495
19년 전 조회 2,411
19년 전 조회 2,795
19년 전 조회 2,170
19년 전 조회 3,498
19년 전 조회 1,966
19년 전 조회 2,573
19년 전 조회 1,592
19년 전 조회 2,822
19년 전 조회 3,062
19년 전 조회 2,146
19년 전 조회 1,984
19년 전 조회 2,460
19년 전 조회 2,376
19년 전 조회 3,067
19년 전 조회 6,747
19년 전 조회 2,703
19년 전 조회 3,172
19년 전 조회 3,074
19년 전 조회 1,910
19년 전 조회 3,347
19년 전 조회 2,177
19년 전 조회 2,688
19년 전 조회 2,337
19년 전 조회 4,351
19년 전 조회 2,466
19년 전 조회 2,735
19년 전 조회 3,498
19년 전 조회 3,702
19년 전 조회 3,225
🐛 버그신고