묻고답하기

지금하는내용이 스크롤하면 그옆에 따라 내려가는 플로팅메뉴입니다.

밑의 코드가 위에꺼는 웹화면에 나오는 div부분이구 아래꺼가 jsp안에서 쓰인 자바스크립트코드입니다 . 안에 길이를 너무많이 차지해서 따로 javascript source file로 이름은 floating.js로 만들어서 거기다 붙여넣기해서 jsp안에

이거썻는데도 기능이 안먹네요ㅠㅠ 왜그런걸까요?

 

<div class="article">
<div id="floatdiv" style="padding: 16px; border: 2px solid black; border-image: none; left: 1269px;
 top: 10px; width: 233px; height: 46px; position: absolute; z-index: 1; background-color: whitesmoke;
  layer-background-color: red;">
  <span style="color: rosybrown;">
플로팅메뉴
  </span> 
  </div>                
</div>

 

<script type="text/javascript">
var floatingMenuId = 'floatdiv';
var floatingMenu =
{
    targetX: -250,
    targetY: 10,

    hasInner: typeof(window.innerWidth) == 'number',
    hasElement: document.documentElement
        && document.documentElement.clientWidth,

    menu:
        document.getElementById
        ? document.getElementById(floatingMenuId)
        : document.all
          ? document.all[floatingMenuId]
          : document.layers[floatingMenuId]
};


floatingMenu.move = function ()
{
    if (document.layers)
    {
        floatingMenu.menu.left = floatingMenu.nextX;
        floatingMenu.menu.top = floatingMenu.nextY;
    }
    else
    {
        floatingMenu.menu.style.left = floatingMenu.nextX + 'px';
        floatingMenu.menu.style.top = floatingMenu.nextY + 'px';
    }
}

floatingMenu.computeShifts = function ()
{
    var de = document.documentElement;

    floatingMenu.shiftX =
        floatingMenu.hasInner
        ? pageXOffset
        : floatingMenu.hasElement
          ? de.scrollLeft
          : document.body.scrollLeft;
    if (floatingMenu.targetX < 0)
    {
        if (floatingMenu.hasElement && floatingMenu.hasInner)
        {
            // Handle Opera 8 problems
            floatingMenu.shiftX +=
                de.clientWidth > window.innerWidth
                ? window.innerWidth
                : de.clientWidth
        }
        else
        {
            floatingMenu.shiftX +=
                floatingMenu.hasElement
                ? de.clientWidth
                : floatingMenu.hasInner
                  ? window.innerWidth
                  : document.body.clientWidth;
        }
    }

    floatingMenu.shiftY = 
        floatingMenu.hasInner
        ? pageYOffset
        : floatingMenu.hasElement
          ? de.scrollTop
          : document.body.scrollTop;
    if (floatingMenu.targetY < 0)
    {
        if (floatingMenu.hasElement && floatingMenu.hasInner)
        {
            // Handle Opera 8 problems
            floatingMenu.shiftY +=
                de.clientHeight > window.innerHeight
                ? window.innerHeight
                : de.clientHeight
        }
        else
        {
            floatingMenu.shiftY +=
                floatingMenu.hasElement
                ? document.documentElement.clientHeight
                : floatingMenu.hasInner
                  ? window.innerHeight
                  : document.body.clientHeight;
        }
    }
}

floatingMenu.doFloat = function()
{
    var stepX, stepY;

    floatingMenu.computeShifts();

    stepX = (floatingMenu.shiftX + 
        floatingMenu.targetX - floatingMenu.nextX) * .07;
    if (Math.abs(stepX) < .5)
    {
        stepX = floatingMenu.shiftX +
            floatingMenu.targetX - floatingMenu.nextX;
    }

    stepY = (floatingMenu.shiftY + 
        floatingMenu.targetY - floatingMenu.nextY) * .07;
    if (Math.abs(stepY) < .5)
    {
        stepY = floatingMenu.shiftY + 
            floatingMenu.targetY - floatingMenu.nextY;
    }

    if (Math.abs(stepX) > 0 ||
        Math.abs(stepY) > 0)
    {
        floatingMenu.nextX += stepX;
        floatingMenu.nextY += stepY;
        floatingMenu.move();
    }

    setTimeout('floatingMenu.doFloat()', 20);
};

// addEvent designed by Aaron Moore
floatingMenu.addEvent = function(element, listener, handler)
{
    if(typeof element[listener] != 'function' || 
       typeof element[listener + '_num'] == 'undefined')
    {
        element[listener + '_num'] = 0;
        if (typeof element[listener] == 'function')
        {
            element[listener + 0] = element[listener];
            element[listener + '_num']++;
        }
        element[listener] = function(e)
        {
            var r = true;
            e = (e) ? e : window.event;
            for(var i = element[listener + '_num'] -1; i >= 0; i--)
            {
                if(element[listener + i](e) == false)
                    r = false;
            }
            return r;
        }
    }

    //if handler is not already stored, assign it
    for(var i = 0; i < element[listener + '_num']; i++)
        if(element[listener + i] == handler)
            return;
    element[listener + element[listener + '_num']] = handler;
    element[listener + '_num']++;
};

floatingMenu.init = function()
{
    floatingMenu.initSecondary();
    floatingMenu.doFloat();
};

// Some browsers init scrollbars only after
// full document load.
floatingMenu.initSecondary = function()
{
    floatingMenu.computeShifts();
    floatingMenu.nextX = floatingMenu.shiftX +
        floatingMenu.targetX;
    floatingMenu.nextY = floatingMenu.shiftY +
        floatingMenu.targetY;
    floatingMenu.move();
}

if (document.layers)
    floatingMenu.addEvent(window, 'onload', floatingMenu.init);
else
{
    floatingMenu.init();
    floatingMenu.addEvent(window, 'onload',
        floatingMenu.initSecondary);
}

</script>

 

글쓴이 제목 최종 글
XE 공지 글 쓰기,삭제 운영방식 변경 공지 [16] 2019.03.05 by 남기남
xe사용자권한 xe메인 화면 게시판 오류입니다 ㅠㅠ  
제자4a6a3 회원가입부분 질문. [4] 2016.10.19 by 제자4a6a3
SnH매니저 XE 초보자 도움요청 합니다... [3] 2016.10.19 by 제로캠프
락앤락 스케치북 모바일 스킨 질문이요!!! [1] 2016.10.19 by 최윤한
mootoreal 관리자페이지 대시보드 최근글에서 날짜 보이는 방법이요.. [1] file 2016.10.19 by sejin7940
harry77 외부접속 문제... [8] 2016.10.19 by Arp.
아거월드 한개의 게시판을 서로다른 형태로 구분가능할까요? [1] 2016.10.18 by sejin7940
스마트류 게시판 제목 옆에 뜨는 '이미지'아이콘 감추는 방법?? [4] file 2016.10.18 by 스마트류
관리자모드 제로보드 xe홈페이지에 검색창 달기 [5] 2016.10.18 by 제로캠프
바람막이 회원가입 이용약관, 개인정보 애드온 적용 방법 문의 [2] file 2016.10.18 by 바람막이
WCGM PHP7.0, mariadb-10.0.x 에서도 사용할 수 있는지요? [5] 2016.10.18 by sejin7940
귀염귀염나무 SSL에 관련되어 또 초보적인 질문 드립니다.  
추사랑 레이아웃 양옆 광고 문의 [1] file 2016.10.18 by 제로캠프
귀염귀염나무 도메인 고정 질문입니다 [1] 2016.10.18 by ksdflc,mei
bey 모든 게시판의 링크가 홈화면 링크로 바뀌었습니다 [1] 2016.10.18 by ksdflc,mei
orange**** 관리자 페이지 및 회원 로그인이 안되요 [1] file 2016.10.18 by ksdflc,mei
영흥도우럭1 윈컴이님 홈 레이아웃 이름이 뭐예요? [3] 2016.10.18 by 영흥도우럭1
바람막이 회원가입 애드온 적용방법 [1] 2016.10.18 by 제로캠프
바람막이 도메인 세션공유 질문 [2] 2016.10.18 by 바람막이
ppumweb 레이아웃 질문 [1] 2016.10.18 by 제로캠프
이문이100 크롬으로 사이트 접근 제한하는 방법있을까요? [5] file 2016.10.18 by 이문이100
수수 궁금한거 몇개 여쭙겠습니다~ [2] 2016.10.18 by 수수
영흥도우럭1 진짜 좋은 아이디어 ㅎㅎㅎ [10] 2016.10.17 by sejin7940
제대로만들자 1.8.11->1.8.12 업그레이드시..오류.. [1] 2016.10.17 by 제로캠프
관리자페이지에서 업데이트 오류 [3] 2016.10.17 by 제로캠프
컵케익e9f70 xe 외부페이지 불러오기 [5] 2016.10.17 by 제로캠프
쿠닌 https 관련 질문입니다 ㅠㅠ [1] 2016.10.17 by 제로캠프
박세연 게시판 레이아웃 문제입니다.. [1] file 2016.10.17 by 제로캠프
영흥도우럭1 사이트 이전할때요...  
masu**** permission denied 문제 질문드립니다.