圖片下拉選擇器的制作
來(lái)源:易賢網(wǎng) 閱讀:744 次 日期:2014-09-10 15:16:42
溫馨提示:易賢網(wǎng)小編為您整理了“圖片下拉選擇器的制作”,方便廣大網(wǎng)友查閱!

我們先來(lái)看下做出這個(gè)控件需要解決哪些問(wèn)題。

第一,圖片下拉列表框是一個(gè)層,它在選擇提示框點(diǎn)擊時(shí)出現(xiàn),出現(xiàn)后在選擇圖片或窗體點(diǎn)擊時(shí)再隱藏。

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

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

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

第三,圖片下拉列表框的滾動(dòng),要保證自動(dòng)滾動(dòng)到相應(yīng)的圖片出現(xiàn)在列表框的頂端:當(dāng)手動(dòng)滾動(dòng)停止時(shí),如果滾動(dòng)條趨勢(shì)是向下滾動(dòng),則自動(dòng)繼續(xù)向下滾動(dòng)直至最近的圖片在列表框的頂端,反之亦然。

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

〈!--建立表單-->

〈form name="myform" method="post" action="">請(qǐng)選擇圖片:

〈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="/Files/BeyondPic/chinazcj/2005-11/20/05112013271490203.gif"; //供選圖片的路徑。"數(shù)字序號(hào)"四字將在程序中替換為0,1,2...,不要手工更改為數(shù)字 ;

var selectedNo=7; //默認(rèn)選定的圖片序號(hào);

var selecteSize=2; //下拉列表框中顯示的圖片數(shù);

/* 以下把圖片和層輸出在"imgBox"的位置:

我們用變量"isin"記錄鼠標(biāo)是否在該控件上;用CSS定義下拉列表框的滾動(dòng)條,"overflow-x:hidden;overflow-y:scroll;"指水平方向不滾動(dòng),豎直方面滾動(dòng);

用for()循環(huán)依次把圖片輸出到下拉列表框。

*/

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>〈img name="imgselected" border=1 src="'+imgSrc.replace("數(shù)字序號(hào)",selectedNo)+'" WIDTH='+(imgWidth)+' HEIGHT='+imgHeight+'>〈/td>〈td valign=top>〈img src="/Files/BeyondPic/chinazcj/2005-11/20/05112013271481624.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+="〈img listID="+i+" src='"+imgSrc.replace("數(shù)字序號(hào)",i)+"' alt='"+imgSrc.replace("數(shù)字序號(hào)",i)+"' width="+imgWidth+" height="+imgHeight+" onclick='selectme(this)' onload='if(init)init()'>〈BR>";

}

myHTML+= "〈/DIV>〈/SPAN>";

imgBox.outerHTML=myHTML;

/* 以下控制下拉列表框的出現(xiàn)或隱藏 */

function showlist(obj){//這個(gè)函數(shù)將在選擇提示框點(diǎn)擊時(shí)激活

//如果列表框已經(jīng)出現(xiàn),這次點(diǎn)擊則隱藏:

if(imgBox.style.pixelLeft!=-800){imgBox.style.pixelLeft=-800; return;}

//讀取選擇提示框在窗體中的絕對(duì)位置:

//在父容器中的相對(duì)位置:

var mytop=obj.offsetTop;

var myleft=obj.offsetLeft;

//依次讀取父容器在更高一級(jí)父容器中的相對(duì)位置:

while(obj=obj.offsetParent){

myleft+=obj.offsetLeft;

mytop+=obj.offsetTop;

}

//現(xiàn)在已經(jīng)得到選擇提示框的絕對(duì)位置myleft和mytop。

//下拉列表拉就出現(xiàn)在這個(gè)絕對(duì)位置的正下方:

imgBox.style.left=myleft;

imgBox.style.top=mytop+imgHeight+2;

}

var isin=false;

function selectme(obj){ //這個(gè)函數(shù)將在窗體點(diǎn)擊或選定圖片時(shí)激活,窗體點(diǎn)擊中傳遞的參數(shù)是null。

if(!isin||obj){imgBox.style.pixelLeft=-800;} //隱藏列表框

if(obj){

//改變選擇提示框中的圖片和"myhead"輸入框中的值:

//listID是對(duì)象的自定義屬性,即在對(duì)象的標(biāo)簽中定義了這個(gè)屬性值,現(xiàn)在就可以讀取或改變。

myform.myhead.value=imgSrc.replace("數(shù)字序號(hào)",obj.listID);

document.images["imgselected"].src=imgSrc.replace("數(shù)字序號(hào)",obj.listID);

}

}

/* 以下控制下拉列表框的自動(dòng)滾動(dòng) */

var mytime=setTimeout("",0);

var pre_X=0; //這個(gè)變量用來(lái)記錄滾動(dòng)前滾動(dòng)條的位置

function scrollud(){ //本函數(shù)在下拉列表框滾動(dòng)時(shí)被激活

var current_X=imgBox.scrollTop; //記錄函數(shù)激活時(shí)滾動(dòng)條的位置

//判斷向上還是向下滾動(dòng),并自動(dòng)滾動(dòng)到"imgHeight"的整數(shù)倍。

//我們改變列表框的scrollTop值時(shí),會(huì)自動(dòng)激發(fā)其onscroll事件,循環(huán)激活本函數(shù)。

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;

}

//使列表框自動(dòng)滾動(dòng)到默認(rèn)選定的圖片位置,并給"myhead"輸入框以默認(rèn)值

function init(){ //本函數(shù)在每個(gè)列表框中的圖片加載時(shí)激活

imgBox.scrollTop=selectedNo*imgHeight;

myform.myhead.value=imgSrc.replace("數(shù)字序號(hào)",selectedNo);

}

/* 以下使窗體點(diǎn)擊時(shí)selectme(obj)函數(shù)被激活: */

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>

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

" width="800">

相信大家都見(jiàn)過(guò)一些軟件里的圖片下拉選擇控件吧?喏,OICQ中就有。但網(wǎng)頁(yè)上的你見(jiàn)過(guò)沒(méi)有?小陽(yáng)今天就為你推出你心怡已久的這個(gè)控件,下面演示中就是了!效果還可以吧?心動(dòng)不如行動(dòng),我們來(lái)看下是怎么弄出來(lái)的。

演示:(點(diǎn)擊這里在新窗口中打開演示頁(yè))

我們先來(lái)看下做出這個(gè)控件需要解決哪些問(wèn)題。

第一,圖片下拉列表框是一個(gè)層,它在選擇提示框點(diǎn)擊時(shí)出現(xiàn),出現(xiàn)后在選擇圖片或窗體點(diǎn)擊時(shí)再隱藏。

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

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

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

第三,圖片下拉列表框的滾動(dòng),要保證自動(dòng)滾動(dòng)到相應(yīng)的圖片出現(xiàn)在列表框的頂端:當(dāng)手動(dòng)滾動(dòng)停止時(shí),如果滾動(dòng)條趨勢(shì)是向下滾動(dòng),則自動(dòng)繼續(xù)向下滾動(dòng)直至最近的圖片在列表框的頂端,反之亦然。

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

〈!--建立表單-->

〈form name="myform" method="post" action="">請(qǐng)選擇圖片:

〈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="/Files/BeyondPic/chinazcj/2005-11/20/05112013271490203.gif"; //供選圖片的路徑。"數(shù)字序號(hào)"四字將在程序中替換為0,1,2...,不要手工更改為數(shù)字 ;

var selectedNo=7; //默認(rèn)選定的圖片序號(hào);

var selecteSize=2; //下拉列表框中顯示的圖片數(shù);

/* 以下把圖片和層輸出在"imgBox"的位置:

我們用變量"isin"記錄鼠標(biāo)是否在該控件上;用CSS定義下拉列表框的滾動(dòng)條,"overflow-x:hidden;overflow-y:scroll;"指水平方向不滾動(dòng),豎直方面滾動(dòng);

用for()循環(huán)依次把圖片輸出到下拉列表框。

*/

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>〈img name="imgselected" border=1 src="'+imgSrc.replace("數(shù)字序號(hào)",selectedNo)+'" WIDTH='+(imgWidth)+' HEIGHT='+imgHeight+'>〈/td>〈td valign=top>〈img src="/Files/BeyondPic/chinazcj/2005-11/20/05112013271481624.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+="〈img listID="+i+" src='"+imgSrc.replace("數(shù)字序號(hào)",i)+"' alt='"+imgSrc.replace("數(shù)字序號(hào)",i)+"' width="+imgWidth+" height="+imgHeight+" onclick='selectme(this)' onload='if(init)init()'>〈BR>";

}

myHTML+= "〈/DIV>〈/SPAN>";

imgBox.outerHTML=myHTML;

/* 以下控制下拉列表框的出現(xiàn)或隱藏 */

function showlist(obj){//這個(gè)函數(shù)將在選擇提示框點(diǎn)擊時(shí)激活

//如果列表框已經(jīng)出現(xiàn),這次點(diǎn)擊則隱藏:

if(imgBox.style.pixelLeft!=-800){imgBox.style.pixelLeft=-800; return;}

//讀取選擇提示框在窗體中的絕對(duì)位置:

//在父容器中的相對(duì)位置:

var mytop=obj.offsetTop;

var myleft=obj.offsetLeft;

//依次讀取父容器在更高一級(jí)父容器中的相對(duì)位置:

while(obj=obj.offsetParent){

myleft+=obj.offsetLeft;

mytop+=obj.offsetTop;

}

//現(xiàn)在已經(jīng)得到選擇提示框的絕對(duì)位置myleft和mytop。

//下拉列表拉就出現(xiàn)在這個(gè)絕對(duì)位置的正下方:

imgBox.style.left=myleft;

imgBox.style.top=mytop+imgHeight+2;

}

var isin=false;

function selectme(obj){ //這個(gè)函數(shù)將在窗體點(diǎn)擊或選定圖片時(shí)激活,窗體點(diǎn)擊中傳遞的參數(shù)是null。

if(!isin||obj){imgBox.style.pixelLeft=-800;} //隱藏列表框

if(obj){

//改變選擇提示框中的圖片和"myhead"輸入框中的值:

//listID是對(duì)象的自定義屬性,即在對(duì)象的標(biāo)簽中定義了這個(gè)屬性值,現(xiàn)在就可以讀取或改變。

myform.myhead.value=imgSrc.replace("數(shù)字序號(hào)",obj.listID);

document.images["imgselected"].src=imgSrc.replace("數(shù)字序號(hào)",obj.listID);

}

}

/* 以下控制下拉列表框的自動(dòng)滾動(dòng) */

var mytime=setTimeout("",0);

var pre_X=0; //這個(gè)變量用來(lái)記錄滾動(dòng)前滾動(dòng)條的位置

function scrollud(){ //本函數(shù)在下拉列表框滾動(dòng)時(shí)被激活

var current_X=imgBox.scrollTop; //記錄函數(shù)激活時(shí)滾動(dòng)條的位置

//判斷向上還是向下滾動(dòng),并自動(dòng)滾動(dòng)到"imgHeight"的整數(shù)倍。

//我們改變列表框的scrollTop值時(shí),會(huì)自動(dòng)激發(fā)其onscroll事件,循環(huán)激活本函數(shù)。

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;

}

//使列表框自動(dòng)滾動(dòng)到默認(rèn)選定的圖片位置,并給"myhead"輸入框以默認(rèn)值

function init(){ //本函數(shù)在每個(gè)列表框中的圖片加載時(shí)激活

imgBox.scrollTop=selectedNo*imgHeight;

myform.myhead.value=imgSrc.replace("數(shù)字序號(hào)",selectedNo);

}

/* 以下使窗體點(diǎn)擊時(shí)selectme(obj)函數(shù)被激活: */

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>

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

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:圖片下拉選擇器的制作
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)