首頁 >web前端 >css教學 >怎樣用CSS3來取代JS實現互動效果

怎樣用CSS3來取代JS實現互動效果

php中世界最好的语言
php中世界最好的语言原創
2018-03-21 16:17:142404瀏覽

這次帶給大家怎樣用CSS3來取代JS實現互動效果,用CSS3來取代JS實現互動效果的注意事項有哪些,下面就是實戰案例,一起來看一下。

【CSS3和JS】

對於CSS了解的同學都知道,CSS的實作是最底層的,在實作方式和效能上都不是,JS這種提供介面的腳本可比的;從CSS3的動畫和JS動畫對比角度來看兩者,會更清晰;而且隨著前端框架的使用,頁面動畫會越來越多的應用CSS3

【CSS3的其他用法】

除了動畫的代替,還有就是對於各種交互的實現上,也體現了CSS的強大,更多的是使用CSS3提供的選擇器;

先來看個例子:可以更好的體現我這次對於CSS的深刻感悟

c9ccee2e6ea535a969eb3f532ad9fe89
body{background:#f4f4f4;margin:0;}
/*list*/
.listcon{}
.listcon .box{background:#fff;position:relative;border-bottom:solid 1px #858585;overflow:hidden;}
.listcon .box:hover{background:#f4f4f4;-webkit-transition:all .6s;transition:all .6s;}
.listcon .box:hover .delete{-webkit-transition:all .6s;transition:all .6s;opacity:1;}
.listcon .input{-webkit-appearance:none;appearance:none;position:absolute;top:10px;left:12px;padding:0;border:none;margin:0;width:24px;height:24px;border:solid 2px red;border-radius:50%;box-sizing:border-box;outline:none;cursor:pointer;}
.listcon .input:checked::after{content:'';width:14px;height:14px;background:red;position:absolute;top:3px;left:3px;border-radius:50%;}
.listcon label{line-height:24px;padding:10px 0 10px 48px;display:block;-webkit-transition:all .4s;transition:all .4s;}
.listcon .input:checked+label{color:#d9d9d9;text-decoration:line-through;}
.listcon .delete{width:44px;height:44px;float:right;position:relative;cursor:pointer;opacity:0;}
.listcon .delete:hover::after{-webkit-transform:rotate(225deg);transform:rotate(225deg);}
.listcon .delete:hover::before{-webkit-transform:rotate(225deg);transform:rotate(225deg);}
.listcon .delete::after{content:'';position:absolute;width:2px;height:20px;background:red;top:12px;left:50%;margin-left:-1px;-webkit-transform:rotate(45deg);transform:rotate(45deg);border-radius:4px;-webkit-transition:all .6s;transition:all .6s;}
.listcon .delete::before{content:'';position:absolute;width:20px;height:2px;background:red;top:50%;left:12px;margin-top:-1px;-webkit-transform:rotate(45deg);transform:rotate(45deg);border-radius:4px;-webkit-transition:all .6s;transition:all .6s;}
531ac245ce3e4fe3d50054a55f265927
28859b2ba70e98e5703d7b62483afef7
    9890cd3db8af2c13be66110fccb4c149
        efa64630fb67b2f5e868af04ec249fd694b3e26ee717c64999d7867364b1b4a3
        4cd7a1c97800370822b14b86c8fd82a0
        2e1cf0710519d5598b1f0f14c36ba674啥地方垃圾费8c1ecd4bb896b2264e0711597d40766c
    94b3e26ee717c64999d7867364b1b4a3
94b3e26ee717c64999d7867364b1b4a3

【說明】

上麵包括了諸多的交互,hover的交互、checked的交互;

對於上面的實現方法相信,早已經有很多人實現了;這裡主要說說我對於這次的感悟和對於技術的憧憬,到現在工作也有近四年了,在這些年中,成長快慢自知,但相同的一點就是,很多知識都會用,也知道怎麼用;可這次才真正明白,什麼叫只知其意,不知其真意,為何!

上面的互動效果,在之前我都是用css和js結合的方式實現;期間也嘗試著全部使用css實現交互效果,不過卻在探索的時候故步自封導致到現在才真正的實現當初的想法;

使用CSS完全實現的好處,提高了可復用性和可維護性,對於實現相應組件提供了更好的實現方式,同時也提高了性能;

.listcon .input:checked+label

如上面這種用法,我們可以使用CSS3增加的各種強大的選擇器,實現更多更好的互動效果;從此離開使用JS改變DOM的悲劇,更多的傾向於CSS

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

CSS定製文字省略的方法

#css的絕對定位怎麼相容於所有的解析度

以上是怎樣用CSS3來取代JS實現互動效果的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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