• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • 網頁圖片下拉選擇控件使用實例

    發表于:2007-06-21來源:作者:點擊數: 標簽:
    上周五在大富翁上看到如何在網頁的下拉列表中顯示圖片一文,便做了一個mark,準備用周末思考一下。誰知道昨天出去玩一天,今天來收到郵件,問題解決了。 不想看內容的,請下載rar文件。下面是轉貼: 相信大家都見過一些軟件里的圖片下拉選擇控件吧?喏,OI CQ

       

      上周五在大富翁上看到如何在網頁的下拉列表中顯示圖片一文,便做了一個mark,準備用周末思考一下。誰知道昨天出去玩一天,今天來收到郵件,問題解決了。

      不想看內容的,請下載rar文件。下面是轉貼:

      相信大家都見過一些軟件里的圖片下拉選擇控件吧?喏,OICQ中就有。但網頁上的你見過沒有?小陽今天就為你推出你心怡已久的這個控件,下面演示中就是了!效果還可以吧?心動不如行動,我們來看下是怎么弄出來的。

      我們先來看下做出這個控件需要解決哪些問題。

      第一,圖片下拉列表框是一個層,它在選擇提示框點擊時出現,出現后在選擇圖片或窗體點擊時再隱藏。

      它出現時位置要在選擇提示框的正下方;隱藏實際上可以把它的位置定在屏幕之外(style.pixelLeft=-800)。

      第二,圖片下拉列表框的位置。選擇提示框不是層,圖片下拉列表框出現的位置要在選擇提示框的正下方,就必須讀取選擇提示框在窗體中的絕對位置,不能受選擇提示框的位置和屏幕分辨率的影響。

      我們可以用“Object.offsetLeft”和“Object.offsetTop”獲取對象(Object)在其父容器(offsetParent)中的相對位置。于是我們可以用while()循環向高一級父容器一層一層讀取相對位置,它們的代數和就是該Object在最上層容器(窗體)中的絕對位置了。

      第三,圖片下拉列表框的滾動,要保證自動滾動到相應的圖片出現在列表框的頂端:當手動滾動停止時,如果滾動條趨勢是向下滾動,則自動繼續向下滾動直至最近的圖片在列表框的頂端,反之亦然。

      例子中我們將所有供選圖片命名為“0.gif”、“1.gif”……“9.gif”,并放在“head”目錄下。下面我們以實際程序解決這些問題:

    <!--建立表單-->
    <form name="myform" method="post" action="">請選擇圖片:
    <div id="imgBox"><!--這里是圖片下拉選擇器的位置--></div>
    <input name="myhead" type="text" id="myface" size="10" value="">
    </form>
    <script language="JavaScript">
    <!--
    var imgWidth=64; //列表框中圖片的寬度;
    var imgHeight=64; //列表框中圖片的高度;
    var imgSrc="head/數字序號.gif"; //供選圖片的路徑。
    "數字序號"四字將在程序中替換為0,1,2...,不要手工更改為數字 ;
    var selectedNo=7; //默認選定的圖片序號;
    var selecteSize=2; //下拉列表框中顯示的圖片數;

    /* 以下把圖片和層輸出在"imgBox"的位置:
    我們用變量"isin"記錄鼠標是否在該控件上;用CSS定義下拉列表框的滾動條,
    "overflow-x:hidden;overflow-y:scroll;"指水平方向不滾動,
    豎直方面滾動;
    用for()循環依次把圖片輸出到下拉列表框。
    */
    var myHTML='<SPAN onmouseover="isin=true" onmouseout="isin=false">';
    myHTML+='<table width="1" onclick="showlist(this)"
    title="選擇提示框" border="0" cellspacing="0" cellpadding="0"><tr><td>
    <clearcase/" target="_blank" >ccid_file name="imgselected" border=1 values="+imgSrc"
    WIDTH=+(imgWidth)+ HEIGHT=+imgHeight+ /></td><td valign=top>
    <ccid_file values="menu" src="menu.gif" /></td></tr></table>';
    myHTML+='<DIV onscroll="scrollud()" id="imgBox" \n';
    myHTML+='style="position:absolute;left=-800;
    top=0;background-color:#FFFFFF;border: 1px solid #000000;overflow-x:hidden;overflow-y:scroll;
    width:'+(imgWidth+20)+'px; height: '+imgHeight*selecteSize+'px">';
    for(i=0;i<10;i++){
    myHTML+="<ccid_file listID="+i+" values="+imgSrc" alt=
    "+imgSrc.replace("數字序號",i)+" width="+imgWidth+"
    height="+imgHeight+" onclick=selectme(this)
    onload=if(init)init() /><BR>";
    }
    myHTML+= "</DIV></SPAN>";
    imgBox.outerHTML=myHTML;
    /* 以下控制下拉列表框的出現或隱藏 */
    function showlist(obj){//這個函數將在選擇提示框點擊時激活
    //如果列表框已經出現,這次點擊則隱藏:
    if(imgBox.style.pixelLeft!=-800){imgBox.style.pixelLeft=-800; return;}
    //讀取選擇提示框在窗體中的絕對位置:
    //在父容器中的相對位置:
    var mytop=obj.offsetTop;
    var myleft=obj.offsetLeft;
    //依次讀取父容器在更高一級父容器中的相對位置:
    while(obj=obj.offsetParent){
    myleft+=obj.offsetLeft;
    mytop+=obj.offsetTop;
    }
    //現在已經得到選擇提示框的絕對位置myleft和mytop。
    //下拉列表拉就出現在這個絕對位置的正下方:
    imgBox.style.left=myleft;
    imgBox.style.top=mytop+imgHeight+2;
    }
    var isin=false;
    function selectme(obj){ //這個函數將在窗體點擊或選定圖片時激活,
    窗體點擊中傳遞的參數是null。
    if(!isin||obj){imgBox.style.pixelLeft=-800;} //隱藏列表框
    if(obj){
    //改變選擇提示框中的圖片和"myhead"輸入框中的值:
    //listID是對象的自定義屬性,即在對象的標簽中定義了這個屬性值,
    現在就可以讀取或改變。
    myform.myhead.value=imgSrc.replace("數字序號",obj.listID);
    document.images["imgselected"].src=imgSrc.replace("數字序號",obj.listID);
    }
    }
    /* 以下控制下拉列表框的自動滾動 */
    var mytime=setTimeout("",0);
    var pre_X=0; //這個變量用來記錄滾動前滾動條的位置
    function scrollud(){ //本函數在下拉列表框滾動時被激活
    var current_X=imgBox.scrollTop; //記錄函數激活時滾動條的位置
    //判斷向上還是向下滾動,并自動滾動到"imgHeight"的整數倍。
    //我們改變列表框的scrollTop值時,會自動激發其onscroll事件,
    循環激活本函數。
    if(current_X>pre_X && imgBox.scrollTop<
    Math.ceil(imgBox.scrollTop/imgHeight)*imgHeight){
    clearTimeout(mytime);
    mytime=setTimeout
    ("imgBox.scrollTop=Math.round(imgBox.scrollTop+1);",1);
    }
    else if(current_X<pre_X && imgBox.scrollTop> Math.floor(imgBox.scrollTop/imgHeight)*imgHeight){
    clearTimeout(mytime);
    mytime=setTimeout("imgBox.scrollTop=Math.round
    (imgBox.scrollTop-1);",1);
    }
    pre_X=current_X;
    }
    //使列表框自動滾動到默認選定的圖片位置,并給"myhead"輸入框以默認值
    function init(){ //本函數在每個列表框中的圖片加載時激活
    imgBox.scrollTop=selectedNo*imgHeight;
    myform.myhead.value=imgSrc.replace("數字序號",selectedNo);
    }
    /* 以下使窗體點擊時selectme(obj)函數被激活: */
    myActivation="selectme(null)";
    if(document.body.onclick)
    {
    eval(document.body.onclick.toString().replace
    ('anonymous()','bodyclick()'));
    document.body.onclick=new Function("bodyclick();"+myActivation);
    }
    else document.body.onclick=new Function(myActivation);
    -->
    </script>

      程序最后“使窗體點擊時selectme(obj)函數被激活”部分可以用document.body.onclick=new Function("selectme(null)")簡單替換之。但為了不和其它程序的窗體點擊事件沖突,我們用了這段代碼。


      你也可以將"myhead" 的type值設為"hide",這里為了演示,就將它顯示了出來。


      好了,這個控件“圖片下拉選擇器”已經做好了,把它應用到留言本、論壇等動態交互的網頁上,真是最好不過了!

    原文轉自:http://www.kjueaiud.com

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>