亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

基于Bootstrap里面的Button dropdown打造自定義select

 更新時間:2016年05月30日 14:15:00   作者:快樂八哥  
這篇文章主要介紹了基于Bootstrap里面的Button dropdown打造自定義select的相關(guān)資料,非常不錯具有參考借鑒價值,需要的朋友可以參考下

最近工作非常的忙,在對一個系統(tǒng)進(jìn)行改版。項(xiàng)目后臺是MVC1.0開發(fā)的,但是前端部分已經(jīng)改過幾個版本,而已之前的設(shè)計(jì)師很強(qiáng)大,又做設(shè)計(jì)又做前端開發(fā)。而已很時尚和前沿,使用了一直都很熱門的Bootstrap工具包,有很多把它定義為Web前端CSS框架。說實(shí)話,之前只知道它是Twitter公司出品,界面做的比較好看。但是沒有在實(shí)際項(xiàng)目中使用,之前公司新來的同事會這個,準(zhǔn)備在公司官網(wǎng)項(xiàng)目中使用,因?yàn)槲也粫?,而已Leader對這個也不感冒,所以就沒有用。而已她說配合Less一起做項(xiàng)目,可以提高開發(fā)效率,而已可以把系統(tǒng)做的更漂亮和美觀,而已對自適應(yīng)設(shè)計(jì)支持比較好。

項(xiàng)目需求是將HTML原生的select標(biāo)簽替換為下圖所示的下拉框效果。我一般看到這種需求,要改變原生的html標(biāo)簽,就不太喜歡弄。雖然也知道通過ui和li標(biāo)簽,加上Javascript代碼可以實(shí)現(xiàn)和select一樣的功能,但是之前也沒有嘗試去寫過,到時bug和瀏覽器兼容性有問題,和PM溝通,是不是不要改這個select,就用原生的select,PM說是為減低用戶干擾,讓用戶不要太在意這個選擇項(xiàng)。我覺得也是這個道理,首先長的不想select那么夸張,其次那個下拉箭頭有點(diǎn)小,用戶也不會太刻意去點(diǎn)擊。其實(shí)點(diǎn)擊那個文字也是會把下面下拉列表打開的。

image(HTML原生select標(biāo)簽) image(最終效果圖)

(HTML原生select標(biāo)簽)

 

select原始功能是可以點(diǎn)擊右側(cè)的下拉箭頭可以打開下拉列表,給用戶選擇。用戶選擇一個選項(xiàng),文本框里面的值要變成對應(yīng)的option的內(nèi)容,并且可以獲取到option的value值。另外一個很重要的功能是option有一個selected屬性。如果某個option有selected=”selected”,那么下拉框默認(rèn)會選中當(dāng)前這個option。

Bootstrap提供Button Dropdown是為了來做漂亮的菜單,壓根不是想做select的功能。當(dāng)我搜索看到它時,我還以為Bootstrap可以提供類似button dropdown樣式的select組件。不過我是妄想,沒有這個組件,必須組件實(shí)現(xiàn)。其實(shí)有過用ul和li寫select標(biāo)簽的經(jīng)驗(yàn),寫這個也不是很困難。

<div class="dropdown" style="margin-top:30px;">
<a style="font-size:14px;" class="btn dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown">
Text 1
<span class="caret"></span>
</a>
<ul class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu1">
<li role="presentation" value=><a role="menuitem" tabindex="1" href="#">Text 1</a></li>
<li role="presentation"><a role="menuitem" tabindex="2" href="#">Text 2</a></li>
<li role="presentation"><a role="menuitem" tabindex="3" href="#">Text 3</a></li>
</ul>
</div>

這個是Button Dropdown的基本代碼。因?yàn)樗旧頃?yīng)用css樣式,而已我們后面要改bootstrap.min.css里面的樣式,所以我們需要在這個頁面單獨(dú)放一些樣式。

<!DOCTYPE html>
<html>
<head>
<title>Bootstrap 101 Template</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0" charset="utf-8">
<!-- Bootstrap -->
<link href="css/bootstrap.css" rel="stylesheet">
<style type="text/css">
.btn-group.open .dropdown-toggle
{
-webkit-box-shadow:none;
box-shadow:none;
}
</style>
<!--[if lt IE 9]>
<script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
<script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
<![endif]-->
</head>
<body>
<p>原始的select標(biāo)簽</p>
<select>
<option value="1">Text 1</option>
<option value="2">Text 2</option>
<option value="3">Text 3</option>
</select>
<div id="dropdown1" class="dropdown" style="margin-top:30px;">
<div class="btn-group">
<a style="font-size:14px;" class="btn dropdown-toggle" type="button" id="dropdownMenu1" data-toggle="dropdown">
<!--選中option之后,要在這里顯示選中值,類似原始select里面的文本框--> 
<span class="placeholder">Text 1</span>
<span class="caret"></span>
</a>
<ul class="dropdown-menu" role="menu" aria-labelledby="dropdownMenu1">
<li role="presentation" value="1"><a role="menuitem" tabindex="1" href="javascript:void(0);">Text 1</a></li>
<li role="presentation" value="2"><a role="menuitem" tabindex="2" href="javascript:void(0);">Text 2</a></li>
<li role="presentation" value="3"><a role="menuitem" tabindex="3" href="javascript:void(0);">Text 3</a></li>
</ul>
</div>
</div>
<!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->
<script src="js/jquery-1.10.2.js"></script>
<!-- Include all compiled plugins (below), or include individual files as needed -->
<script src="js/bootstrap.min.js"></script>
<script type="text/javascript">
function customDropDown(ele){
this.dropdown=ele;
this.placeholder=this.dropdown.find(".placeholder");
this.options=this.dropdown.find("ul.dropdown-menu > li");
this.val='';
this.index=-1;//默認(rèn)為-1;
this.initEvents();
}
customDropDown.prototype={
initEvents:function(){
var obj=this;
//這個方法可以不寫,因?yàn)辄c(diǎn)擊事件被Bootstrap本身就捕獲了,顯示下面下拉列表
obj.dropdown.on("click",function(event){
$(this).toggleClass("active");
});

//點(diǎn)擊下拉列表的選項(xiàng)
obj.options.on("click",function(){
var opt=$(this);
obj.text=opt.find("a").text();
obj.val=opt.attr("value");
obj.index=opt.index();
obj.placeholder.text(obj.text);
});
},
getText:function(){
return this.text;
},
getValue:function(){
return this.val;
},
getIndex:function(){
return this.index;
}
}
$(document).ready(function(){
var mydropdown=new customDropDown($("#dropdown1"));
});
</script>
</body>
</html>

點(diǎn)擊過程中會出現(xiàn)一個背景。通過Chrome查看元素,是寫box-shodow的效果。但是我改過之后,還是出現(xiàn)了。明天繼續(xù)查找一下。

添加1行樣式覆蓋,bootstrap.css里面本身的樣式。

<style type="text/css">
.btn-group.open .dropdown-toggle
{
-webkit-box-shadow:none;
box-shadow:none;
}
</style>

注意事項(xiàng):在實(shí)例化的過程中,我們傳入的是一個jQuery選擇器的對象,所以如果一個頁面有很多自定義的dropdown,會使用類別。那在實(shí)例化的過程要修改一下代碼哦!

Demo演示地址:http://liminjun.sinaapp.com/demo/customselect/index.html

Bootstrap CDN http://www.bootstrapcdn.com/ 百度雖然也有了,但是版本有點(diǎn)老,也不去更新。

Bootstrap官網(wǎng) http://getbootstrap.com/components/#btn-dropdowns

相關(guān)文章

最新評論