jQuery模擬實(shí)現(xiàn)的select點(diǎn)擊選擇效果【附demo源碼下載】
本文實(shí)例講述了jQuery模擬實(shí)現(xiàn)的select點(diǎn)擊選擇效果。分享給大家供大家參考,具體如下:
有時(shí)候有些HTML元素?zé)o法讓我們用樣式控制進(jìn)行控制,但是射雞師或是客戶的需求就是需要這種效果,還要讓每個(gè)瀏覽器都顯示同樣的效果,這時(shí)候就會(huì)讓我們這些所謂的前端攻城師很蛋疼,客戶會(huì)認(rèn)為交了點(diǎn)錢不讓你折騰些東西,以為你是沒做事的。面對(duì)這些對(duì)技術(shù)一竅不通的客戶,技術(shù)對(duì)于他們來說就是一坨屎,以為我們都是用意念來寫代碼做程序的,所以都把我們的勞動(dòng)成果看作是廉價(jià)得像是簡(jiǎn)單的拉出一泡屎而已。
雖然很喜歡什么都沒有修飾的默認(rèn)效果,但是又不得不面對(duì)這些客戶蛋疼的效果和要求,所以不得不折騰幾個(gè)來回總不滿足,HTML里面,不可以樣式控制的元素恐怕也為數(shù)不多,select是其中的一個(gè),,所以今天也來折騰一下這個(gè)比較喜歡自由不愛樣式約束的元素,采用模擬的方式來實(shí)現(xiàn)select的效果。
采用模擬的好處可以任意的進(jìn)行樣式控制,做出各種各樣的效果,在各個(gè)瀏覽器中的表現(xiàn)都一致,實(shí)現(xiàn)客戶蛋疼的要求,但缺點(diǎn)也是同樣的存在的,網(wǎng)絡(luò)非常慢或客戶端禁止運(yùn)行腳本的時(shí)候//(盡管腳本禁止運(yùn)行的機(jī)率很低,一般只會(huì)有服務(wù)器版本的瀏覽器上才會(huì)出現(xiàn)),腳本加載不到有可能會(huì)影響到其失效,無(wú)法進(jìn)行操作,
其實(shí)這個(gè)效果早已廣泛應(yīng)用,也不算什么新鮮的了,大家可以隨便看一下比較新一點(diǎn)的網(wǎng)站都能找到,下面分別是淘寶和拍拍上也采用模擬的select的截圖。
淘寶模擬select:
拍拍模擬select:
本例實(shí)現(xiàn)效果:
實(shí)現(xiàn)的思路很簡(jiǎn)單,只有兩步:
1、當(dāng)鼠標(biāo)進(jìn)行移入和點(diǎn)擊的目標(biāo)元素的時(shí)候,觸發(fā)彈出一個(gè)層,層內(nèi)裝著模擬的不同的元素的值
2、點(diǎn)擊選擇層內(nèi)的元素的時(shí)候,需要將點(diǎn)擊元素文本元素賦到目標(biāo)元素中,并將元素內(nèi)的一些參數(shù)值傳到一個(gè)隱藏的域中進(jìn)行傳值
于是就有了以下的HTML、CSS和操作JS:
html:
<span class="selectType"> <a title="" href="#" class="ipt" id="selectTypeText">全部</a> <span id="selectTypeMenu"> <a rel="0" title="" href="#">全部</a> <a rel="1" title="" href="#">商品</a> <a rel="2" title="" href="#">商鋪</a> </span> <input type="hidden" name="" class="ipt" value="" id="selectTypeRel"> <em class="searchArrow hh abs">下拉選擇</em> </span>
css:
.sysSelect{width:76px; height:28px; line-height:28px; border:1px solid #CCC; font-size:14px;} .sysSelect option{height:28px; line-height:28px;} .selectType{position:relative; width:78px; height:30px; line-height:30px; font-size:14px;} .selectType .ipt{width:76px; height:28px; line-height:28px; border:1px solid #CCC; display:inline-block; text-decoration:none; color:#000; text-indent:5px; outline:none;} .selectType span{position:absolute; width:76px; background-color:#fff; border:1px solid #CCC; border-top-style:dashed; left:0px; top:22px; text-indent:6px; line-height:26px; display:none;} .selectType span a{color:#333; display:block; text-decoration:none;} .selectType span a:hover{background-color:#f60; color:#fff;} .selectType .searchArrow{border-top:6px solid #666; border-left:6px solid #FFF; border-right:6px solid #FFF; position:absolute; width:0; height:0; top:6px; right:12px; cursor:pointer; -webkit-transition:-webkit-transform 0.2s ease-in; -moz-transition:-moz-transform 0.2s ease-in; -o-transition:-o-transform 0.2s ease-in; transition:transform 0.2s ease-in; overflow:hidden; text-indent:-2000px;} .selectType .searchArrowRote{-moz-transform:rotate(180deg); -moz-transform-origin:50% 30%; -webkit-transform:rotate(180deg); -webkit-transform-origin:50% 30%; -o-transform:rotate(180deg); -o-transform-origin:50% 30%; transform:rotate(180deg);transform-origin:50% 30%; filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2); top:-9px/9;}
js:
$("#selectTypeText").click(function () { $(this).next("span").slideDown(200); $(".searchArrow").addClass("searchArrowRote"); }); $("#selectTypeText").blur(function () { $(this).next("span").slideUp(200); $(".searchArrow").removeClass("searchArrowRote"); }); $("#selectTypeMenu>a").click(function () { $("#selectTypeText").text($(this).text()); $("#selectTypeRel").attr("value", $(this).attr("rel")); $(this).parent().slideUp(200); $(".searchArrow").removeClass("searchArrowRote"); return false; });
你是否還期待著我的長(zhǎng)篇大論?但很遺憾的告訴你,說明已經(jīng)完畢了,也就是這么簡(jiǎn)單了,幾行代碼一看也就明白了。
還有不明白的?那沒問題,請(qǐng)看DEMO,點(diǎn)擊此處打開。
完整demo源碼點(diǎn)擊此處本站下載。
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery窗口操作技巧總結(jié)》、《jQuery拖拽特效與技巧總結(jié)》、《jQuery常用插件及用法總結(jié)》、《jquery中Ajax用法總結(jié)》、《jQuery表格(table)操作技巧匯總》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常見經(jīng)典特效匯總》、《jQuery動(dòng)畫與特效用法總結(jié)》及《jquery選擇器用法總結(jié)》
希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。
相關(guān)文章
jQuery文本框得到與失去焦點(diǎn)動(dòng)態(tài)改變樣式效果
這篇文章主要介紹了jQuery文本框得到與失去焦點(diǎn)動(dòng)態(tài)改變樣式效果,涉及jQuery針對(duì)頁(yè)面表單元素樣式的動(dòng)態(tài)操作技巧,需要的朋友可以參考下2016-09-09Jquery高級(jí)應(yīng)用Deferred對(duì)象原理及使用實(shí)例
這篇文章主要介紹了Jquery高級(jí)應(yīng)用Deferred對(duì)象原理及使用實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05jQuery Selectors(選擇器)的使用(七、子元素篇)
本系列文章主要講述jQuery框架的選擇器(Selectors)使用方法,我將以實(shí)例方式進(jìn)行講述,以簡(jiǎn)單,全面為基礎(chǔ),不會(huì)涉及很深,我的學(xué)習(xí)方法:先入門,后進(jìn)階!2009-12-12jquery將一個(gè)表單序列化為一個(gè)對(duì)象的方法
將表單序列化為一個(gè)對(duì)象的方法有很多,在本文為大家介紹下使用jquery是如何做到的,感興趣的朋友可以參考下2014-01-01基于jquery的實(shí)現(xiàn)簡(jiǎn)單的表格中增加或刪除下一行
下面的代碼利用jquery簡(jiǎn)單的實(shí)現(xiàn)表格中增加和刪除一行,很簡(jiǎn)單。2010-08-08jQuery中attr()和prop()在修改checked屬性時(shí)的區(qū)別
使用語(yǔ)句$.attr('checked',true),將復(fù)選框的屬性改為被選中,在chrome瀏覽器中第一次點(diǎn)擊有效后面就不行了,IE8倒是沒有問題2014-07-07jQuery通過擴(kuò)展實(shí)現(xiàn)抖動(dòng)效果的方法
這篇文章主要介紹了jQuery通過擴(kuò)展實(shí)現(xiàn)抖動(dòng)效果的方法,涉及jQuery擴(kuò)展的技巧及抖動(dòng)特效的實(shí)現(xiàn)方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03jQuery中數(shù)據(jù)緩存$.data的用法及源碼完全解析
這篇文章主要介紹了jQuery中的數(shù)據(jù)緩存$.data的用法及源碼完全解析,深入解讀了jQuery對(duì)緩存對(duì)象的讀寫和移除的實(shí)現(xiàn),需要的朋友可以參考下2016-04-04