首頁  >  文章  >  web前端  >  CSS 下拉框特效_HTML5中國

CSS 下拉框特效_HTML5中國

巴扎黑
巴扎黑原創
2017-05-27 10:42:142487瀏覽

CSS 下拉框特效_HTML5中國

  想要製作這麼一個效果還是比較麻煩的,但是程式碼並不難理解。首先,來看看 Html 程式碼。

<p class="container">
    <p class="heading">
        <h2>Custom Select</h2>
    </p>

    <p class="select">
        <p>Please select</p>
        <ul>
            <li data-value="HTML5">HTML5</li>
            <li data-value="CSS3">CSS3</li>
            <li data-value="JavaScript">JavaScript</li>
            <li data-value="JQuery">JQuery</li>
            <li data-value="Backbone">Backbone</li>
        </ul>
    </p>
</p>

      可見,我們並沒有利用原生的 select 元素,而是利用其它元素來模擬這個效果。我們為 li 元素指定了 data-value,主要是接下來我們會用 JQuery 取得選取值並將其放置到 p 元素下。

下面逐步來看 CSS 程式碼。

   * {
        margin: 0;
        padding: 0;
    }

    html {
        font-family: &#39;Terminal&#39;;
        font-size: 62.5%;
    }

    body {
        background-color: #33CC66;
    }
  1.   將網頁中所有元素的外邊距和內邊距設為 0。

  2.   將網頁中的預設字體設定為 Terminal,字體大小設定為 62.5%, 也就是 10px。

  3.   設定背景顏色為 #33CC66。

 <link href=&#39;http://fonts.googleapis.com/css?family=Lobster|Terminal+Dosis&#39; rel=&#39;stylesheet&#39; type=&#39;text/css&#39;>

  上面我們用到了 Terminal 字體,而且接下來我們還會使用 Lobster 字體,所以用這行程式碼加入引用。

   .heading, .select {
        display: block;
        width: 22rem;
        margin: 0 auto;
        text-align: center;
    }

    .heading {
        width: 28rem;
        margin-top: 10rem;
        margin-bottom: 2rem;
    }

    .heading h2 {
        font-size: 6rem;
        font-family: &#39;Lobster&#39;;
        color: #ffffff;
    }
  1.   指定 headng, select 寬度並指定其水平居中。

  2.   修改 heading 的寬度,主要是為了讓其寬度大於 select 的寬度,顯得更加美觀。然後指定其上外邊距和下外邊距。

  3.   設定 heading 下 h2 元素的字體和字體大小,顏色。

.select > p, .select ul {
        background-color: #ffffff;
        font-size: 2rem;
        border: 1px solid bisque;
        border-radius: 5px;
        margin-bottom: 0;
    }

.select > p {
        text-align: left;
        padding: 1rem;
        position: relative;
        border-bottom-right-radius: 0;
        border-bottom-left-radius: 0;
        cursor: pointer;
        color: rgba(102, 102, 102, .6);
    }
.select > p:after {
        display: block;
        width: 10px;
        height: 10px;
        content: &#39;&#39;;
        position: absolute;
        top: 1.4rem;
        right: 2rem;
        border-bottom: 1px solid #33CC66;
        border-left: 1px solid #33CC66;
        transform: rotate(-45deg);
        transition: transform .3s ease-out, top .2s ease-out;
    }
  1.   設定 p 和 ul 元素的背景顏色和邊框等設定。

  2.   為 p 元素單獨指定樣式,並設定其 position 屬性,主要是為了下方繪製右側的下拉按鈕。

  3.   利用 :after 在p 元素的右邊繪製下拉按鈕,可以看出來,我們是利用左下方邊框然後旋轉 -45 度 模擬的這個效果。值得注意的是,我們需要將其 display 設定為 block,並且設定寬高,否則看不到 這個效果。

.select ul {
        margin-top: 0;
        border-top-left-radius: 0;
        border-top-right-radius: 0;
        list-style-type: none;
        cursor: pointer;
        overflow-y: auto;
        max-height: 0;
        transition: max-height .3s ease-out;
    }

    .select ul li {
        padding-left: 0.5rem;
        display: block;
        line-height: 3rem;
        text-align: left;
    }
  1.   設定ul 的一些預設屬性,並將其設定最大寬度為0,指定overflow-y 為auto ,這個時候ul 將會被隱藏。

  2.   在這裡設定的時候我遇到了一個問題,就是 li 標籤總是佔不滿 ul 的一行,那是因為其預設有 margin 和 padding ,所以在一開始的時候就將網頁中所有元素的外邊距和內邊距設定成了 0。

    .select.open ul {
        max-height: 20rem;
        transform-origin: 50% 0;
        -webkit-animation: slide-down .5s ease-in;
    }

    .select.open > p:after {
        position: absolute;
        top: 1.6rem;
        transform: rotate(-225deg);
        transition: transform .3s ease-in, top .2s ease-in;
    }
  1.   為 open 設定最大高度,並為其指定動畫效果。

  2.   將下拉按鈕旋轉 -225 度,並為其指定動畫。

  下面我們來看看為 ul 元素指定的 slide-down 動畫效果,這也是這個下拉特效的關鍵所在。

   @-webkit-keyframes slide-down {
        0% {
            transform: scale(1, 0);
        }
        25% {
            transform: scale(1, 1.25);
        }
        50% {
            transform: scale(1, 0.75);
        }
        75% {
            transform: scale(1, 1.1);
        }
        100% {
            transform: scale(1, 1);
        }
    }

  看到以上程式碼可能就都明白了,就是不斷改變ul 的大小,讓其在0.75-1.25 之間進行縮放,所以就會有那個跳動的效果了。

  下面還有一些簡單的 CSS 程式碼,不再解釋。

   .select ul li:hover {
        background-color: rgba(102, 153, 102, 0.4);
    }

    .select .selected {
        background-color: rgba(102, 153, 102, 0.8);
    }

  CSS 講完了,下面就可以看看我們是如何利用 JQuery 來控制這個效果的。

  我們並不需要下載 JQuery 就可以使用,因為現在已經有許多網站提供了 CDN 服務,像是我使用的 BootCDN。

<script src="http://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>

  下面就可以使用 JQuery 了。

<script>
    $(document).ready(function () {
        $(&#39;.select ul li&#39;).on("click", function (e) {
            var _this = $(this);
            $(&#39;.select >p&#39;).text(_this.attr(&#39;data-value&#39;));
            $(_this).addClass(&#39;selected&#39;).siblings().removeClass(&#39;selected&#39;);
            $(&#39;.select&#39;).toggleClass(&#39;open&#39;);
            cancelBubble(e);
        });

        $(&#39;.select>p&#39;).on("click", function (e) {
            $(&#39;.select&#39;).toggleClass(&#39;open&#39;);
            cancelBubble(e);
        });

        $(document).on(&#39;click&#39;, function () {
            $(&#39;.select&#39;).removeClass(&#39;open&#39;);
        })
    })

    function cancelBubble(event) {
        if (event.stopPropagation) {
            event.preventDefault();
            event.stopPropagation();
        } else {
            event.returnValue = false;
            event.cancelBubble();
        }
    }
</script>
  •   先為 p 標籤綁定 click 事件,在觸發的時候,為 select 新增或移除 open class, 也就是將 ul 顯示出來。

  •   為li 綁定click 事件,當選取了一個li 元素的時候,首先取得data-value,然後將其賦值為p 標籤,然後為選取的li 新增 selected class,同時利用 siblings() 方法,讓兄弟節點的 selected class 移除。

  • Set the click event for document. When we click anywhere on the web page, if ul is open, close it. However, at this time, since all elements are document, so we need to prevent the event from bubbling and call the cancelBubble() method we wrote ourselves.

以上是CSS 下拉框特效_HTML5中國的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn