首頁 > web前端 > js教程 > jQuery結合CSS製作漂亮的select下拉選單

jQuery結合CSS製作漂亮的select下拉選單

PHPz
發布: 2018-10-15 15:09:03
原創
1334 人瀏覽過

我們在進行表單設計時,可能要用到select下拉選項控件,遺憾的是,IE瀏覽器預設的select控件外觀非常醜陋,而且不能用樣式來控制,不能在選項中添加圖片等資訊。今天我將透過實例來講解如何用CSS和jQuery來製作漂亮的下拉選項選單。

XHTML

请选择城市长沙北京南京堪培拉多伦多
登入後複製
登入後複製

可以看出,我們使用div來取代下拉選項控制項原生的select標籤。
CSS

#dropdown{width:186px; margin:80px auto; position:relative} 
#dropdown p{width:150px; height:24px; line-height:24px; padding-left:4px; padding-right:30px; 
border:1px solid #a9c9e2; background:#e8f5fe url(arrow.gif) no-repeat right 4px; 
color:#807a62; cursor:pointer} 
#dropdown ul{width:184px; background:#e8f5fe; margin-top:2px; border:1px solid #a9c9e2; 
position:absolute; display:none} 
#dropdown ul li{height:24px; line-height:24px; text-indent:10px} 
#dropdown ul li a{display:block; height:24px; color:#807a62; text-decoration:none} 
#dropdown ul li a:hover{background:#c6dbfc; color:#369}
登入後複製

樣式不要多講,你可以修改CSS中的背景色和字體顏色,甚至其他任意定義的樣式。有一個下拉箭頭的小圖標,已經打包在附件裡了。
jQuery
首先,當按一下「請選擇城市」時,判斷下拉的圖層「ul」是否處於顯示狀態,如果是則隱藏下拉選項,否則則開啟(下滑)下拉選項

$("#dropdown p").click(function(){ 
  var ul = $("#dropdown ul"); 
  if(ul.css("display")=="none"){ 
    ul.slideDown("fast"); 
  }else{ 
    ul.slideUp("fast"); 
  } 
});
登入後複製

然後,當按一下下拉選項時,取得選項內容,將選項內容寫入

標籤中,同時隱藏下拉選項。

$("#dropdown ul li a").click(function(){ 
  var txt = $(this).text(); 
  $("#dropdown p").html(txt); 
  $("#dropdown ul").hide(); 
});
登入後複製

這樣就完成了一個簡單的下拉選項的操作,是不是很簡單啊。
當然,如果與後台交互,需要取得選項的value值,那就需要先定義XHTML。

请选择城市长沙北京南京堪培拉多伦多
登入後複製
登入後複製

從程式碼中可以看出,在給a標籤加個rel屬性,並賦值,就相當於select的option標籤的value值。接下來就是透過jQuery取得rel值,請看程式碼:

$("#dropdown ul li a").click(function(){ 
  var txt = $(this).text(); 
  $("#dropdown p").html(txt); 
  var value = $(this).attr("rel"); 
  $("#dropdown ul").hide(); 
  $("#result").html("您选择了"+txt+",值为:"+value); 
});
登入後複製

這樣就完成了一個完整的下拉選項的操作。

以上所述就是本文的全部內容了,希望大家能夠喜歡。

【相關教學推薦】

1. JavaScript影片教學
2. JavaScript線上手冊
3. bootstrap教學

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板