中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

圖片下拉選擇器的制作
來源:易賢網 閱讀:1511 次 日期:2014-10-09 09:46:13
溫馨提示:易賢網小編為您整理了“圖片下拉選擇器的制作”,方便廣大網友查閱!

這里在新窗口中打開演示頁)

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

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

它出現時位置要在選擇提示框的正下方;隱藏實際上可以把它的位置定在屏幕之外(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="/Files/BeyondPic/chinazcj/2005-11/20/05112013271490203.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>〈img name="imgselected" border=1 src="'+imgSrc.replace("數字序號",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("數字序號",i)+"' 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)")簡單替換之。但為了不和其它程序的窗體點擊事件沖突,我們用了這段代碼。

" width="800">

相信大家都見過一些軟件里的圖片下拉選擇控件吧?喏,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="/Files/BeyondPic/chinazcj/2005-11/20/05112013271490203.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>〈img name="imgselected" border=1 src="'+imgSrc.replace("數字序號",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("數字序號",i)+"' 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)")簡單替換之。但為了不和其它程序的窗體點擊事件沖突,我們用了這段代碼

更多信息請查看IT技術專欄

更多信息請查看腳本欄目
上一篇:javascript技巧2
易賢網手機網站地址:圖片下拉選擇器的制作
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
**性色生活片久久毛片| 欧美午夜宅男影院| 亚洲男人av电影| 国产日韩av高清| 蜜臀a∨国产成人精品| 亚洲大片av| 欧美日韩亚洲一区在线观看| 一区二区三区欧美激情| 国产乱码精品一区二区三区不卡| 久久精品视频在线| 影音先锋中文字幕一区| 国产精品国产a| 久热成人在线视频| 欧美主播一区二区三区| 日韩天堂在线视频| 亚洲激情国产| 国产性做久久久久久| 欧美视频二区36p| 美日韩在线观看| 亚洲自拍偷拍视频| 日韩西西人体444www| 激情久久婷婷| 国产酒店精品激情| 国产精品视频久久久| 欧美日韩成人综合| 久久人人97超碰精品888 | 激情视频一区二区三区| 欧美日韩国产麻豆| 老鸭窝亚洲一区二区三区| 久久久欧美精品| 久久久久久久网站| 欧美va亚洲va国产综合| 欧美v日韩v国产v| 欧美承认网站| 欧美国产激情二区三区| 欧美成人一区二区三区在线观看| 欧美理论电影网| 国产精品va在线播放| 国产精品亚洲片夜色在线| 国产欧美日韩免费| 在线欧美视频| 欧美一区二区三区的| 免费在线国产精品| 国产视频一区在线| 亚洲图片欧美午夜| 欧美成人一区二区在线 | 欧美国产欧美亚州国产日韩mv天天看完整| 久久久久久午夜| 国产精品久久一区主播| **性色生活片久久毛片| 午夜久久一区| 欧美日韩视频在线一区二区观看视频| 国产精品久久999| 亚洲激情校园春色| 久久在线观看视频| 亚洲精品在线观| 午夜精品一区二区三区电影天堂| 久久久国产成人精品| 国产精品国产三级国产专区53| 伊人久久大香线| 欧美一区二区私人影院日本 | 久久五月天婷婷| 国色天香一区二区| 欧美一区二区视频在线观看2020 | 日韩手机在线导航| 欧美一级播放| 国产精品vip| 亚洲一区二区三区精品在线观看| 欧美mv日韩mv国产网站| 好吊视频一区二区三区四区 | 亚洲欧美日韩高清| 久久精品99国产精品日本| 欧美日韩在线播放一区二区| 国产亚洲精品久久久| 欧美伊人久久久久久久久影院| 亚洲风情在线资源站| 久久精品视频在线看| 欧美四级伦理在线| 国产精品99久久久久久久久久久久| 欧美国产日本在线| 日韩亚洲成人av在线| 欧美美女bb生活片| 亚洲综合首页| 夜夜嗨av一区二区三区| 麻豆精品传媒视频| 在线视频你懂得一区二区三区| 久久久夜夜夜| 一区二区三区免费网站| 国产婷婷色一区二区三区在线| 久久丁香综合五月国产三级网站| 悠悠资源网久久精品| 国产精品久久二区| 久久精品国产精品亚洲| 野花国产精品入口| 国产精品视频内| 欧美gay视频激情| 久久久视频精品| 亚洲一区二区三| 一本久久综合亚洲鲁鲁| 尤物九九久久国产精品的分类| 欧美精品久久久久久久免费观看| 欧美一区二区三区啪啪| 99热在线精品观看| 亚洲日韩成人| 亚洲国产欧美日韩| 亚洲黄色av一区| 亚洲激情电影在线| 亚洲激情av| 亚洲人永久免费| 亚洲日韩成人| 亚洲第一黄网| 国产欧美日韩视频一区二区三区| 欧美激情网站在线观看| 久久久天天操| 欧美bbbxxxxx| 欧美理论大片| 欧美日韩国产亚洲一区| 欧美日韩不卡在线| 欧美性色aⅴ视频一区日韩精品| 久久久久综合| 久久久免费精品| 欧美日韩卡一卡二| 国产伦精品一区二区三区视频孕妇 | 国产欧美一区二区三区沐欲| 欧美大片在线观看一区| 欧美日韩p片| 午夜精品国产更新| 美女视频一区免费观看| 国产精品久久二区二区| 国产婷婷成人久久av免费高清| 91久久国产综合久久91精品网站| 亚洲人成高清| 一本色道久久88精品综合| 欧美激情第8页| 国产免费成人| 国产精品99久久久久久人 | 国产日韩欧美| 在线观看亚洲精品| 欧美一级专区免费大片| 欧美激情bt| 国语自产精品视频在线看一大j8 | 欧美日韩另类字幕中文| 国产无一区二区| 亚洲中字黄色| 国产精品一区二区三区观看| 国产午夜久久| 在线视频国内自拍亚洲视频| 亚洲欧美日韩成人| 国产伦精品一区二区三区视频黑人| 亚洲国产综合在线看不卡| 久久久水蜜桃| 国产偷自视频区视频一区二区| 一本大道久久精品懂色aⅴ| 欧美亚洲一区二区三区| 国产精品精品视频| 亚洲图色在线| 精久久久久久| 欧美激情在线观看| 亚洲国产一区二区三区在线播| 麻豆精品一区二区av白丝在线| 国产亚洲亚洲| 久久精品72免费观看| 在线观看中文字幕不卡| 美女福利精品视频| 尤物九九久久国产精品的分类| 日韩一区二区精品视频| 久久久激情视频| 欧美新色视频| 亚洲国产精品福利| 欧美人成在线视频| 亚洲综合色网站| 久久理论片午夜琪琪电影网| 久久精品99国产精品日本| 国产精品一区二区视频| 亚洲欧美久久久| 在线日韩av| 亚洲欧美日韩综合aⅴ视频| 亚洲第一区在线| 欧美日韩在线播| 欧美成人免费全部| 久久av一区二区三区漫画| 91久久线看在观草草青青| 欧美三区在线| 欧美精品一区二区三区四区| 亚洲精品综合久久中文字幕| 欧美性生交xxxxx久久久| 蜜桃久久精品一区二区| 欧美一区二区三区日韩| 亚洲欧美一区在线| 亚洲精品免费在线| 黑人一区二区| 国产精品网站一区| 国产免费成人av| 国产免费成人在线视频| 国产精品免费视频xxxx| 欧美国产免费| 午夜电影亚洲| 亚洲日本成人女熟在线观看| 欧美日韩一区二区三区| 欧美在线国产精品|