리자

셀렉트박스와 레이어가 겹칠시 레이어가 셀렉트 박스 뒤로 숨는 현상을 해결하는 함수

· 21년 전 · 6255
<script language='JavaScript'>
// Internet Explorer에서 셀렉트박스와 레이어가 겹칠시 레이어가 셀렉트 박스 뒤로 숨는 현상을 해결하는 함수
// 레이어가 셀렉트 박스를 침범하면 셀렉트 박스를 hidden 시킴
// 사용법 :
// <div id=LayerID style="display:none; position:absolute;" onpropertychange="selectbox_hidden('LayerID')">
function selectbox_hidden(layer_id)
{
var ly = eval(layer_id);

// 레이어 좌표
var ly_left = ly.offsetLeft;
var ly_top = ly.offsetTop;
var ly_right = ly.offsetLeft + ly.offsetWidth;
var ly_bottom = ly.offsetTop + ly.offsetHeight;

// 셀렉트박스의 좌표
var el;

for (i=0; i<document.forms.length; i++) {
for (k=0; k<document.forms[i].length; k++) {
el = document.forms[i].elements[k];
if (el.type == "select-one") {
var el_left = el_top = 0;
var obj = el;
if (obj.offsetParent) {
while (obj.offsetParent) {
el_left += obj.offsetLeft;
el_top += obj.offsetTop;
obj = obj.offsetParent;
}
}
el_left += el.clientLeft;
el_top += el.clientTop;
el_right = el_left + el.clientWidth;
el_bottom = el_top + el.clientHeight;

// 좌표를 따져 레이어가 셀렉트 박스를 침범했으면 셀렉트 박스를 hidden 시킴
if ( (el_left >= ly_left && el_top >= ly_top && el_left <= ly_right && el_top <= ly_bottom) ||
(el_right >= ly_left && el_right <= ly_right && el_top >= ly_top && el_top <= ly_bottom) ||
(el_left >= ly_left && el_bottom >= ly_top && el_right <= ly_right && el_bottom <= ly_bottom) ||
(el_left >= ly_left && el_left <= ly_right && el_bottom >= ly_top && el_bottom <= ly_bottom) )
el.style.visibility = 'hidden';
}
}
}
}

// 감추어진 셀렉트 박스를 모두 보이게 함
function selectbox_visible()
{
for (i=0; i<document.forms.length; i++) {
for (k=0; k<document.forms[i].length; k++) {
el = document.forms[i].elements[k];
if (el.type == "select-one" && el.style.visibility == 'hidden')
el.style.visibility = 'visible';
}
}
}
</script><div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]</div>
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
20년 전 조회 2,131
20년 전 조회 2,826
20년 전 조회 1,785
20년 전 조회 1,671
20년 전 조회 2,618
20년 전 조회 1,527
20년 전 조회 1,787
20년 전 조회 3,276
20년 전 조회 1,932
20년 전 조회 1,660
20년 전 조회 4,990
20년 전 조회 4,628
20년 전 조회 3,561
20년 전 조회 3,828
20년 전 조회 7,103
20년 전 조회 3,594
20년 전 조회 2,664
20년 전 조회 2,667
20년 전 조회 7,222
20년 전 조회 4,636
20년 전 조회 1,934
20년 전 조회 3,294
20년 전 조회 1,986
20년 전 조회 1,601
20년 전 조회 2,353
20년 전 조회 1,828
20년 전 조회 1,495
20년 전 조회 1,857
20년 전 조회 3,027
20년 전 조회 2,489
20년 전 조회 1,779
20년 전 조회 1,702
20년 전 조회 4,030
20년 전 조회 2,969
20년 전 조회 3,691
20년 전 조회 3,483
21년 전 조회 3,785
21년 전 조회 8,607
21년 전 조회 2,631
21년 전 조회 3,785
21년 전 조회 3,246
21년 전 조회 2,650
21년 전 조회 2,715
21년 전 조회 2,631
21년 전 조회 2,906
21년 전 조회 3,087
21년 전 조회 5,342
21년 전 조회 3,947
21년 전 조회 4,995
21년 전 조회 6,256
21년 전 조회 7,386
21년 전 조회 1.8만
21년 전 조회 6,923
21년 전 조회 2,927
21년 전 조회 4,185
21년 전 조회 2,527
21년 전 조회 4,349
21년 전 조회 2,936
21년 전 조회 2,283
21년 전 조회 2,506
21년 전 조회 2,270
21년 전 조회 2,610
21년 전 조회 1,785
21년 전 조회 1,623
21년 전 조회 1,682
21년 전 조회 2,161
21년 전 조회 1,919
21년 전 조회 2,420
21년 전 조회 3,610
21년 전 조회 1,611
21년 전 조회 1,806
21년 전 조회 3,223
21년 전 조회 2,390
21년 전 조회 3,208
21년 전 조회 2,922
21년 전 조회 3,344
21년 전 조회 5,166
21년 전 조회 2,566
21년 전 조회 4,865
21년 전 조회 2,552
21년 전 조회 3,155
21년 전 조회 7,666
21년 전 조회 3,879
21년 전 조회 3,255
21년 전 조회 4,734
21년 전 조회 2,950
21년 전 조회 6,272
21년 전 조회 4,525
21년 전 조회 5,829
21년 전 조회 3,681
21년 전 조회 6,014
21년 전 조회 3,152
21년 전 조회 2,874
21년 전 조회 2,670
21년 전 조회 2,484
21년 전 조회 2,681
21년 전 조회 2,723
21년 전 조회 3,840
21년 전 조회 2,856
21년 전 조회 2,508