2

웹 브라우저에서 클라이언트보기의 맨 아래에 막대를 붙일 필요가 있습니다. 전통적으로 나는 position : fixed를 사용할 것이다. 단, IE 6 클라이언트를 지원해야합니다. 페이지 하단과 내용 위에 막대를 붙이기 위해 매우 광범위한 해킹이 있었지만 사용자가 아래로 또는 오른쪽으로 스크롤하면 막대가 페이지에 고정되어 있습니다.IE 6,7,8에서 페이지 하단에 막대를 유지하려면 어떻게해야합니까? IE가 인터페이스를 다시 그리도록 강요하는 방법은 무엇입니까?

이 문제를 해결하려면 setInterval을 사용하여 실행되는 자바 스크립트 이벤트를 사용하고 IE (8)의 디버그 도구에서 함수를 실행할 때 이벤트가 발생하고 위치가 왼쪽 위와 왼쪽 위 속성을 변경하지만 페이지는 변경되지 않습니다. 요소를 다시 그립니다. 코드는 작동하지만 요소는 움직이지 않습니다 (아래 참조). 당신은 수정이 IE에서 작동하는 그냥 알다시피

The example shown.

은 다른 IE 버전이 표준을 사용하려고하는 경우가 작동하지 않을 수 있습니다 ... 모드를 쿼크. 저를 믿으십시오, 나는 시도했다.

P. 이것은 IE9 지원을 이중으로 확인하기 때문에 실제로 악화되고 있습니다 ... IE6, 7 및 8에서는 스크롤 막대와 함께 이동하지 않지만 IE 9에서는 이동하지만 IE의 경우에도 여전히 그렇습니다. " 그리고 마이크로 소프트는이 릴리스 아무것도에 영향을 ...하지 않을 것이라고 말했다

HTML 구조

<body> 
    <div id="j_zoom_area" style="zoom:100%;"> 
     The Application area the the zoom is changed (by the bar) for accessibility... 
    </div> 
    <div id="j_protectorite"> 
     <div class="j_bar"> 
     <div class="j_plate">Zoom Controls, Help, Search, other misc controls</div> 
     <div class="j_plate">Copyright info, privacy policy, etc...</div> 
     </div> 
    </div> 
    <script type="text/javascript" language="javascript"> 
     j_doBar(); 
    </script> 
</body> 

바의 CSS는 https://kscserver.com/ERP-API/Style/includes.css입니다. 바 수정을위한 특정 자바 스크립트입니다.

//This controls the scrolling of the bar 
function j_FixBarSlowly(){ 
var nTop = 0; 
var nLeft = 0; 

nTop = (document.body.scrollTop + document.body.clientHeight) - 67; 
nLeft = document.body.scrollLeft; 

//document.title = document.body.scrollTop + '+' + document.body.clientHeight + '-67' + '=' + nTop + 'px'; 
document.getElementById("j_protectorite").style.Top = nTop + 'px'; 
document.getElementById("j_protectorite").style.Left = nLeft + 'px'; 
document.getElementById("j_protectorite").style.Bottom = ''; 
document.getElementById("j_protectorite").style.Position = 'absolute'; 

//Ie6,7,8 hack to force redraw 

} 

function j_doBar() { 
//j_FixBarSlowly(); 

//if (setInterval != undefined) { 
// setTimeout("j_doBar();",5); 
//} else { 
    setInterval("j_FixBarSlowly();",5); 
//} 
} 
+0

, 당신은 아마'추가해야 '페이지의 상단에 (당신은 문서 타입을 가지고하지 않은 경우, 그것은 의심 할 여지가 없다 브라우저 호환성 문제가 있음). – Spudley

+0

내 개인 즐겨 찾기 : Un-IE6 그들 : http://ie6update.com/ 사악한 천재! – bpeterson76

답변

0

더 나은 테스트를 한 후에는 페이지 콘텐츠에 I 프레임을 사용하고 페이지 콘텐츠의 맨 아래에 div가 있어야합니다. 물론 적절한 크기 조정을위한 몇 가지 자바 스크립트 비틀기와 완벽한 솔루션이 있습니다.

시각적 인 참조 용입니다. 당신이 쿼크 모드에서 브라우저를 가지고있는 경우

alt text

0

Dean Edwards' IE7.js과 같은 IE 수정 된 해킹을 사용하는 것이 좋습니다.

이 스크립트는 IE에서 페이지를로드 할 때 실행되며 이전 버전의 IE에서 일반적인 문제를 수정합니다. The documentation은 거래하는 항목을 나열하고 position:fixed;을 포함합니다.

희망이 있습니다.

(물론, 최선의 해결책은 정상적으로 - IE6를 최신 브라우저와 동일하게 보이도록 포기하고 IE6에서 끈적이지 않은 바닥 글을 사용하는 것입니다. 유용성에 영향을 미치지 만 IE6 사용자의 페이지 레이아웃이 약간 떨어지는 문제는 보이지 않지만 일부 사람들은 그렇게하기 힘들다는 것을 알고 있습니다. 사용자가 요구하는 경우에는 사용자가 가지고있는 것입니다. 들을 수있는, 나 아닌!)

+0

안타깝게도 JS 라이브러리에서 수정 된 픽스를 꺼내지 않으면 사용할 수 없습니다. 그것은 잘 작동하는 많은 것들을 뒤집습니다. 귀하의 성명서에 답변하기 위해 고객의 약 50 % (아마도 덜)의 고객이 구형 XP 시스템에서 IE6를 사용합니다. 우리는 붙어 있습니다. – JustinKaz

+0

또 다른 중요한 점은 응용 프로그램이 IE6의 지원으로 인해 IE의 Quirks 모드에서만 잘 작동한다는 것입니다. – JustinKaz

+0

IE6도 doctype이있는 표준 모드에서 더 좋습니다. (부여 된, 그것은 여전히 ​​많은 문제가 있지만없는 것보다 낫다.) – Spudley

관련 문제