我們先來看下做出這個控件需要解決哪些問題。
第一,圖片下拉列表框是一個層,它在選擇提示框點(diǎn)擊時出現(xiàn),出現(xiàn)后在選擇圖片或窗體點(diǎn)擊時再隱藏。
它出現(xiàn)時位置要在選擇提示框的正下方;隱藏實際上可以把它的位置定在屏幕之外(style.pixelLeft=-800)。
第二,圖片下拉列表框的位置。選擇提示框不是層,圖片下拉列表框出現(xiàn)的位置要在選擇提示框的正下方,就必須讀取選擇提示框在窗體中的絕對位置,不能受選擇提示框的位置和屏幕分辨率的影響。
我們可以用“Object.offsetLeft”和“Object.offsetTop”獲取對象(Object)在其父容器(offsetParent)中的相對位置。于是我們可以用while()循環(huán)向高一級父容器一層一層讀取相對位置,它們的代數(shù)和就是該Object在最上層容器(窗體)中的絕對位置了。
第三,圖片下拉列表框的滾動,要保證自動滾動到相應(yīng)的圖片出現(xiàn)在列表框的頂端:當(dāng)手動滾動停止時,如果滾動條趨勢是向下滾動,則自動繼續(xù)向下滾動直至最近的圖片在列表框的頂端,反之亦然。
例子中我們將所有供選圖片命名為“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="/Files/BeyondPic/chinazcj/2005-11/20/05112013271490203.gif"; //供選圖片的路徑。"數(shù)字序號"四字將在程序中替換為0,1,2...,不要手工更改為數(shù)字 ;
var selectedNo=7; //默認(rèn)選定的圖片序號;
var selecteSize=2; //下拉列表框中顯示的圖片數(shù);
/* 以下把圖片和層輸出在"imgBox"的位置:
我們用變量"isin"記錄鼠標(biāo)是否在該控件上;用CSS定義下拉列表框的滾動條,"overflow-x:hidden;overflow-y:scroll;"指水平方向不滾動,豎直方面滾動;
用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ù)字序號",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ù)字序號",i)+"' alt='"+imgSrc.replace("數(shù)字序號",i)+"' width="+imgWidth+" height="+imgHeight+" onclick='selectme(this)' onload='if(init)init()'>〈BR>";
}
myHTML+= "〈/DIV>〈/SPAN>";
imgBox.outerHTML=myHTML;
/* 以下控制下拉列表框的出現(xiàn)或隱藏 */
function showlist(obj){//這個函數(shù)將在選擇提示框點(diǎn)擊時激活
//如果列表框已經(jīng)出現(xiàn),這次點(diǎn)擊則隱藏:
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;
}
//現(xiàn)在已經(jīng)得到選擇提示框的絕對位置myleft和mytop。
//下拉列表拉就出現(xiàn)在這個絕對位置的正下方:
imgBox.style.left=myleft;
imgBox.style.top=mytop+imgHeight+2;
}
var isin=false;
function selectme(obj){ //這個函數(shù)將在窗體點(diǎn)擊或選定圖片時激活,窗體點(diǎn)擊中傳遞的參數(shù)是null。
if(!isin||obj){imgBox.style.pixelLeft=-800;} //隱藏列表框
if(obj){
//改變選擇提示框中的圖片和"myhead"輸入框中的值:
//listID是對象的自定義屬性,即在對象的標(biāo)簽中定義了這個屬性值,現(xiàn)在就可以讀取或改變。
myform.myhead.value=imgSrc.replace("數(shù)字序號",obj.listID);
document.images["imgselected"].src=imgSrc.replace("數(shù)字序號",obj.listID);
}
}
/* 以下控制下拉列表框的自動滾動 */
var mytime=setTimeout("",0);
var pre_X=0; //這個變量用來記錄滾動前滾動條的位置
function scrollud(){ //本函數(shù)在下拉列表框滾動時被激活
var current_X=imgBox.scrollTop; //記錄函數(shù)激活時滾動條的位置
//判斷向上還是向下滾動,并自動滾動到"imgHeight"的整數(shù)倍。
//我們改變列表框的scrollTop值時,會自動激發(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;
}
//使列表框自動滾動到默認(rèn)選定的圖片位置,并給"myhead"輸入框以默認(rèn)值
function init(){ //本函數(shù)在每個列表框中的圖片加載時激活
imgBox.scrollTop=selectedNo*imgHeight;
myform.myhead.value=imgSrc.replace("數(shù)字序號",selectedNo);
}
/* 以下使窗體點(diǎn)擊時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)擊時selectme(obj)函數(shù)被激活”部分可以用document.body.onclick=new Function("selectme(null)")簡單替換之。但為了不和其它程序的窗體點(diǎn)擊事件沖突,我們用了這段代碼。
" width="800">
相信大家都見過一些軟件里的圖片下拉選擇控件吧?喏,OICQ中就有。但網(wǎng)頁上的你見過沒有?小陽今天就為你推出你心怡已久的這個控件,下面演示中就是了!效果還可以吧?心動不如行動,我們來看下是怎么弄出來的。
演示:(點(diǎn)擊這里在新窗口中打開演示頁)
我們先來看下做出這個控件需要解決哪些問題。
第一,圖片下拉列表框是一個層,它在選擇提示框點(diǎn)擊時出現(xiàn),出現(xiàn)后在選擇圖片或窗體點(diǎn)擊時再隱藏。
它出現(xiàn)時位置要在選擇提示框的正下方;隱藏實際上可以把它的位置定在屏幕之外(style.pixelLeft=-800)。
第二,圖片下拉列表框的位置。選擇提示框不是層,圖片下拉列表框出現(xiàn)的位置要在選擇提示框的正下方,就必須讀取選擇提示框在窗體中的絕對位置,不能受選擇提示框的位置和屏幕分辨率的影響。
我們可以用“Object.offsetLeft”和“Object.offsetTop”獲取對象(Object)在其父容器(offsetParent)中的相對位置。于是我們可以用while()循環(huán)向高一級父容器一層一層讀取相對位置,它們的代數(shù)和就是該Object在最上層容器(窗體)中的絕對位置了。
第三,圖片下拉列表框的滾動,要保證自動滾動到相應(yīng)的圖片出現(xiàn)在列表框的頂端:當(dāng)手動滾動停止時,如果滾動條趨勢是向下滾動,則自動繼續(xù)向下滾動直至最近的圖片在列表框的頂端,反之亦然。
例子中我們將所有供選圖片命名為“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="/Files/BeyondPic/chinazcj/2005-11/20/05112013271490203.gif"; //供選圖片的路徑。"數(shù)字序號"四字將在程序中替換為0,1,2...,不要手工更改為數(shù)字 ;
var selectedNo=7; //默認(rèn)選定的圖片序號;
var selecteSize=2; //下拉列表框中顯示的圖片數(shù);
/* 以下把圖片和層輸出在"imgBox"的位置:
我們用變量"isin"記錄鼠標(biāo)是否在該控件上;用CSS定義下拉列表框的滾動條,"overflow-x:hidden;overflow-y:scroll;"指水平方向不滾動,豎直方面滾動;
用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ù)字序號",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ù)字序號",i)+"' alt='"+imgSrc.replace("數(shù)字序號",i)+"' width="+imgWidth+" height="+imgHeight+" onclick='selectme(this)' onload='if(init)init()'>〈BR>";
}
myHTML+= "〈/DIV>〈/SPAN>";
imgBox.outerHTML=myHTML;
/* 以下控制下拉列表框的出現(xiàn)或隱藏 */
function showlist(obj){//這個函數(shù)將在選擇提示框點(diǎn)擊時激活
//如果列表框已經(jīng)出現(xiàn),這次點(diǎn)擊則隱藏:
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;
}
//現(xiàn)在已經(jīng)得到選擇提示框的絕對位置myleft和mytop。
//下拉列表拉就出現(xiàn)在這個絕對位置的正下方:
imgBox.style.left=myleft;
imgBox.style.top=mytop+imgHeight+2;
}
var isin=false;
function selectme(obj){ //這個函數(shù)將在窗體點(diǎn)擊或選定圖片時激活,窗體點(diǎn)擊中傳遞的參數(shù)是null。
if(!isin||obj){imgBox.style.pixelLeft=-800;} //隱藏列表框
if(obj){
//改變選擇提示框中的圖片和"myhead"輸入框中的值:
//listID是對象的自定義屬性,即在對象的標(biāo)簽中定義了這個屬性值,現(xiàn)在就可以讀取或改變。
myform.myhead.value=imgSrc.replace("數(shù)字序號",obj.listID);
document.images["imgselected"].src=imgSrc.replace("數(shù)字序號",obj.listID);
}
}
/* 以下控制下拉列表框的自動滾動 */
var mytime=setTimeout("",0);
var pre_X=0; //這個變量用來記錄滾動前滾動條的位置
function scrollud(){ //本函數(shù)在下拉列表框滾動時被激活
var current_X=imgBox.scrollTop; //記錄函數(shù)激活時滾動條的位置
//判斷向上還是向下滾動,并自動滾動到"imgHeight"的整數(shù)倍。
//我們改變列表框的scrollTop值時,會自動激發(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;
}
//使列表框自動滾動到默認(rèn)選定的圖片位置,并給"myhead"輸入框以默認(rèn)值
function init(){ //本函數(shù)在每個列表框中的圖片加載時激活
imgBox.scrollTop=selectedNo*imgHeight;
myform.myhead.value=imgSrc.replace("數(shù)字序號",selectedNo);
}
/* 以下使窗體點(diǎn)擊時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)擊時selectme(obj)函數(shù)被激活”部分可以用document.body.onclick=new Function("selectme(null)")簡單替換之。但為了不和其它程序的窗體點(diǎn)擊事件沖突,我們用了這段代碼
更多信息請查看IT技術(shù)專欄