셀렉트 박스 내용을 레이어로 표현

· 17년 전 · 2306

<HTML>
<HEAD>
    <TITLE>http://www.blueb.co.kr</TITLE>
<script>

//SELECT -> LAYER변환
function getSelectToLayer(obj,lwidth,href)
{
    if(navigator.userAgent.indexOf('Opera') != -1 || navigator.userAgent.indexOf('MSIE') == -1) { return false; }

    obj.style.display = 'none';
    var newsb = obj.id + "_sbj";
    var newid = obj.id + "_tmp";
    var newim = obj.id + "_img";
    var LayerTag = "";

    LayerTag += "<TABLE WIDTH='"+lwidth+"' CELLSPACING=0 CELLPADDING=0 STYLE='position:absolute;cursor:default;'>";
    LayerTag += "<TR HEIGHT=1><TD></TD></TR><TR><TD>";
    LayerTag += "<TABLE BGCOLOR='#FFFFFF' HEIGHT=15 WIDTH=100% CELLSPACING=1 CELLPADDING=0 STYLE='border:1 solid #C0C0C0;line-height:117%;' onmouseover=\"getSelectLayerOver(this,document.getElementById('"+newim+"'),document.getElementById('"+newid+"'));\" onmouseout=\"getSelectLayerOut(this,document.getElementById('"+newim+"'),document.getElementById('"+newid+"'));\">";
   
    LayerTag += "<TR WIDTH=100% onclick=\"getSelectSubLayer(document.getElementById('"+newid+"'),document.getElementById('"+newsb+"'));\">";
    LayerTag += "<TD ID='"+newsb+"' WIDTH=95% onblur='getSelectLayerBlur(this);'> " + obj.options[obj.selectedIndex].text + "</TD>";
    LayerTag += "<TD ALIGN=RIGHT><IMG ID='"+newim+"' SRC='http://www.blueb.co.kr/image/ico/dot_select.gif' ALIGN=absmiddle STYLE='filter:gray();'></TD></TR>";
   
    LayerTag += "</TABLE>";

    LayerTag += "<TABLE onblur='getSubLayerClose(this);' ID='"+newid+"' WIDTH=100% CELLSPACING=0 CELLPADDING=0 STYLE='display:none;border:1 solid #C0C0C0;' BGCOLOR='#FFFFFF'>";
    for (var i = 0 ; i < obj.length; i++)
    {
        LayerTag += "<TR onmouseover='getSelectMoveLayer(this);' onmouseout='getSelectMoveLayer1(this);' onclick=\"getSelectChangeLayer(document.getElementById('"+obj.id+"'),document.getElementById('"+newid+"'),document.getElementById('"+newsb+"'),'"+obj.options[i].text+"','"+obj.options[i].value+"','"+href+"');\" ";

        if (obj.value == obj.options[i].value)
        {
            LayerTag += "STYLE='background:#225588;color:#FFFFFF;'><TD> ";
        }
        else {
            LayerTag += "STYLE='background:#FFFFFF;color:#000000;'><TD> ";
        }

        LayerTag += obj.options[i].text;
        LayerTag += "</TD></TR>";
    }
    LayerTag += "</TABLE>";
    LayerTag += "</TD></TR></TABLE><IMG SRC='' WIDTH='"+lwidth+"' HEIGHT=0>";

    document.write(LayerTag);
}

//서브레이어보이기
function getSelectSubLayer(obj,sobj)
{
    if(obj.style.display == 'none')
    {
        sobj.style.background = '#FFFFFF';
        sobj.style.color = '#000000';   
        obj.style.display = 'block';
        NowSelectedLayer = obj;
        obj.focus();
    }
    else {
        sobj.style.background = '#225588';
        sobj.style.color = '#FFFFFF';
        obj.style.display = 'none';
    }
}

//서브레이어체크
function getSelectSubLayer1(obj)
{
    if(obj.style.display != 'none')
    {
        obj.style.display = 'none';
    }
}

//타이틀레이어 MouseOver
function getSelectLayerOver(obj,img,nobj)
{
    if (nobj.style.display == 'none')
    {
        obj.style.border = '1 solid #225588';
        img.style.filter = '';
    }
}

//타이틀레이어 MouseOut
function getSelectLayerOut(obj,img)
{
    obj.style.border = '1 solid #C0C0C0';
    img.style.filter = 'gray()';
}


//서브레이어 MouseOver
function getSelectMoveLayer(obj)
{
    if (obj.style.color == '#000000')
    {
        obj.style.background = '#225588';
        obj.style.color = '#FFFFFF';
    }
}
//서브레이어 MouseOut
function getSelectMoveLayer1(obj)
{
    obj.style.background = '#FFFFFF';
    obj.style.color = '#000000';
}

//새레이어선택
function getSelectChangeLayer(obj,fobj,sobj,text,value,href)
{
    if (href)
    {
        eval("document.DataForm." + href).value = value;
        location.href = getThisUrl();
        return false;
    }
    else {
        fobj.style.display = 'none';
        sobj.innerHTML = ' ' + text;
        sobj.style.background = '#225588';
        sobj.style.color = '#FFFFFF';
        sobj.focus();
        obj.value = value;
    }
}

//타이틀레이어 blur
function getSelectLayerBlur(obj)
{
    obj.style.background = '#FFFFFF';
    obj.style.color = '#000000';
}

//서브레이어 닫기
function getSubLayerClose(obj)
{
    if (obj.style.display != 'none')
    {
        setTimeout("document.getElementById('" + obj.id + "').style.display = 'none';" , 150);
    }
}


</script>
</HEAD>

<BODY>
<SELECT ID='search_where'>
<OPTION VALUE="ALL">전체에서</OPTION>
<OPTION VALUE="BB_SUBJECT">제목</OPTION>
<OPTION VALUE="BB_Source">Source</OPTION>
<OPTION VALUE="BB_CONTENT">본문</OPTION>
<script language=javascript>getSelectToLayer(document.getElementById('search_where'),80,''); //검색영역select->layer변환</script>

</SELECT>
</BODY>
</HTML>

[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
17년 전 조회 3,323
17년 전 조회 3,268
17년 전 조회 2,427
17년 전 조회 3,850
17년 전 조회 3,278
17년 전 조회 5,588
17년 전 조회 2,757
17년 전 조회 1,955
17년 전 조회 2,032
17년 전 조회 1,866
17년 전 조회 1,802
17년 전 조회 2,861
17년 전 조회 1,984
17년 전 조회 1,657
17년 전 조회 2,162
17년 전 조회 1,206
17년 전 조회 1,760
17년 전 조회 2,969
17년 전 조회 2,211
17년 전 조회 1,896
17년 전 조회 2,123
17년 전 조회 1,421
17년 전 조회 1,808
17년 전 조회 1,315
17년 전 조회 1,868
17년 전 조회 1,878
17년 전 조회 1,129
17년 전 조회 3,235
17년 전 조회 4,413
17년 전 조회 2,559
17년 전 조회 7,567
17년 전 조회 3,921
17년 전 조회 4,252
17년 전 조회 2,507
17년 전 조회 2,988
17년 전 조회 3,730
17년 전 조회 4,089
17년 전 조회 3,247
17년 전 조회 3,240
17년 전 조회 3,394
17년 전 조회 2,552
17년 전 조회 2,149
17년 전 조회 3,193
17년 전 조회 3,359
17년 전 조회 4,696
17년 전 조회 1,678
17년 전 조회 2,705
17년 전 조회 2,788
17년 전 조회 1,994
17년 전 조회 2,307
17년 전 조회 1,922
17년 전 조회 2,471
17년 전 조회 3,868
17년 전 조회 3,976
17년 전 조회 2,177
17년 전 조회 1,438
17년 전 조회 1,573
17년 전 조회 1,721
17년 전 조회 1,700
17년 전 조회 1,467
17년 전 조회 1,608
17년 전 조회 1,419
17년 전 조회 1,916
17년 전 조회 2,827
17년 전 조회 1,919
17년 전 조회 1,478
17년 전 조회 1,779
17년 전 조회 2,412
17년 전 조회 2,044
17년 전 조회 1,338
17년 전 조회 5,992
17년 전 조회 3,368
17년 전 조회 3,273
17년 전 조회 2,675
17년 전 조회 2,867
17년 전 조회 2,821
17년 전 조회 3,320
17년 전 조회 2,443
17년 전 조회 2,565
17년 전 조회 2,624
17년 전 조회 2,619
17년 전 조회 2,743
17년 전 조회 3,292
17년 전 조회 2,783
17년 전 조회 1,523
17년 전 조회 2,941
17년 전 조회 1,679
17년 전 조회 1,432
17년 전 조회 2,100
17년 전 조회 1,556
17년 전 조회 1,487
17년 전 조회 1,429
17년 전 조회 1,639
17년 전 조회 2,145
17년 전 조회 1,520
17년 전 조회 1,490
17년 전 조회 1,307
17년 전 조회 1,538
17년 전 조회 1,259
17년 전 조회 1,396