溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么利用CSS3實現(xiàn)文本框的清除按鈕相關的一些效果

發(fā)布時間:2021-08-03 17:37:41 來源:億速云 閱讀:179 作者:chen 欄目:web開發(fā)

本篇內容介紹了“怎么利用CSS3實現(xiàn)文本框的清除按鈕相關的一些效果”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

search類型搜索框,設計師常常會設計一個叉叉圖標,表示用戶點之久可以清除輸入的內容。比方說這個:
怎么利用CSS3實現(xiàn)文本框的清除按鈕相關的一些效果

這是不錯的體驗!

當前現(xiàn)代瀏覽器中,Chrome瀏覽器下type=search的輸入框會有清除按鈕的動態(tài)呈現(xiàn),不過搜索input框尺寸不太好控制(padding無視);FireFox瀏覽器貌似任何類型的輸入框都無動于衷;IE10+瀏覽器貌似任何輸入框都會出現(xiàn)清除按鈕,但是長得略微粗糙了點,設計師同學接受不了。

貌似不和諧了,咋辦?傳授個新技能,借助HTML以及CSS,來模擬清除按鈕可動態(tài)呈現(xiàn)的搜索框。

如下CSS:

CSS Code復制內容到剪貼板

  1. .input { padding5pxmargin: 0; border1px solid #beceeb; }   

  2. .clear { displaynonepositionabsolutewidth16pxheight16pxmargin6px 0 0 -20pxbackgroundurl(clear.png);}   

  3. .input::-ms-clear { displaynone; }   

  4. .input:valid + .clear { displayinline; }  

如下HTML:

輸入任意內容:

XML/HTML Code復制內容到剪貼板

  1. <input class="input" required><a class="clear"></a>  

然后就有類似下面截圖的效果了(均截自FireFox瀏覽器):
怎么利用CSS3實現(xiàn)文本框的清除按鈕相關的一些效果

怎么利用CSS3實現(xiàn)文本框的清除按鈕相關的一些效果

手摸為實,眼觀為虛。您可以狠狠地點擊這里:CSS與文本框上清除按鈕顯隱Demo

實現(xiàn)原理   

    HTML部分
    因為search類型文本框在Chrome/Opera/Safari下尺寸不好控制,因此使用缺省的類型(也就是text類型);
    required是必要屬性,配合CSS偽類實現(xiàn)我們的效果。
    CSS部分
    使用的是:valid偽類。這是CSS3中新增偽類,IE10+以及其他現(xiàn)代瀏覽器支持,表示表單合法。由于HTML中的<input>有HTML5表單驗證屬性required. 于是,如果文本框沒有內容,則不合法;有內容,則合法,就會觸發(fā)這里的:valid偽類選擇器。而這里:valid偽類控制后面的清除按鈕顯示,于是就實現(xiàn)了我們想要的效果。

    啊,對了。IE11瀏覽器下不是所有的文本框都有黑色的叉叉嗎,會跟這里的自定義清除按鈕重疊,::-ms-clear { display: none; }這段代碼可以去之~~

    更多偽元素改變表單控件默認樣式可以參考“偽元素改變表單控件默認樣式”一文。

補充于翌日:來公司用IE11測了下,沒效果。后發(fā)現(xiàn),不是偽類不認識,而是兄弟選擇器的渲染bug. 通過修改透明度為0&rarr;1變化,鼠標hover清除按鈕位置,則按鈕出現(xiàn)或隱藏(見下面Gif)。尚未發(fā)現(xiàn)什么奇淫技巧修復這個問題。
怎么利用CSS3實現(xiàn)文本框的清除按鈕相關的一些效果

評論有說mac下Chrome瀏覽器無法清除。經(jīng)自己測試,可以的。如果意思是點擊關閉按鈕清除,確實CSS無能為力。

實現(xiàn)的優(yōu)點
此方法相比傳統(tǒng)JS實現(xiàn)的好處在于,更簡單了。JS的話還要偵聽輸入事件(input)等,比較折騰。CSS的話完全瀏覽器自身事件特性,顯然,高效簡單的多。

實現(xiàn)的不足
不足在于,兼容性。IE9-以下的瀏覽器只能點蠟燭了。

不過,寫寫原型啊,demo;或者漸進增強使用;或者移動端開發(fā)等,都可以試試這個新技能。

注意:點擊叉叉是不會清除的,本文只是輸入控制顯隱??!

“怎么利用CSS3實現(xiàn)文本框的清除按鈕相關的一些效果”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網(wǎng)站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI