CSS实例系列-03-RateLoveScore
时间:2023-03-28 11:33:01
HTML
鏃╀笂濂斤紝涓崍锛屼笅鍗堬紝鍌嶆櫄锛屾繁澶滅殑鏈嬪弸浠紝杩欓噷鏄痡sliang~鎴戜滑浠婂ぉ瑕佸疄鐜扮殑鏄細RateScore杩欎釜闂浼氬拰鏈嬪弸涓€璧疯璁猴細鈭氶€氳繃CSS鐢ㄧ畝鍗曠殑HTML+JS瀹屾垚璇勫垎缁勪欢銆傛湰渚嬩唬鐮佸湴鍧€锛欸ithub-allforoneCodeNuggets-03-RateLoveScoring1鍓嶈█鏈郴鍒桟SS鏂囩珷锛氫富瑕佹帹鑽愬浠ヨ嚧鐢ㄣ€傜粨鍚堥潰璇曢鍜屽伐浣滃疄渚嬶紝璁╁皬浼欎即浠繁搴︿綋楠?1涓父鐢–SS灞炴€у拰鍚勭CSS鐭ヨ瘑銆備富瑕佹槸绾疌SS銆傚敖閲忎娇鐢℉TML+CSS鏉ュ畬鎴愬涔犵洰鐨勶紝浣嗘槸杩樻湁鈥滀竴灏忛儴鍒嗏€濆姛鑳介渶瑕丣avaScript鐭ヨ瘑锛岄€傚悎鏂版墜瀛︿範+楂樻墜澶嶄範銆傚鏋滄枃绔犲湪鏌愪簺缁嗚妭涓婂啓鐨勪笉澶熸竻妤氭垨鑰呰瀵间簡璇昏€咃紝娆㈣繋璇勮/鍚愭Ы/鎵硅瘎锛屼綘浠殑鐐硅禐銆佹敹钘忓拰鍏虫敞鏄垜鏇存柊2.1::before鍜?:after鍏充簬浼厓绱犵殑鍔ㄥ姏::beforeand::afterandcontent锛屾垜浠渶瑕佺畝鍖栫悊瑙o細灏辨槸web鐗堢殑jsliang锛屽悜鍓嶇湅(::before)鍜屽悜鍚庣湅(::after)銆傚叾瀹瀋ontent涓€鑸槸閰嶅悎::before鍜?:after瀹炵幇鍐呭濉厖锛宑ontent:''閰嶅悎width/height瀹屾垚鐭╁舰鐨勭粯鍒讹紙鍜屾櫘閫氱殑div涓€鏍凤級銆?.2閫夋嫨鍣▇鍏充簬閫夋嫨鍣▇锛屼篃寰堝ソ鐞嗚В锛氶棬鍓嶆ˉ涓嬶紝鏈?鍙腑瀛愶紝鏁板埌2鐨勬椂鍊欑敤~锛岀劧鍚庡尮閰?銆?銆?銆備笁涓疄鐜版楠K锛屽皬鐭ヨ瘑鐐硅瀹屼簡锛屾垜浠紑濮嬪啓杩欎釜渚嬪瓙鍚绗竴姝ワ紝HTML缁撴瀯寰堢畝鍗曪細
灏忎紮浼翠滑璧剁揣鎵撳垎鍚 鏄剧ず鏁堟灉濡備笅锛氱浜屾锛屾垜浠簲鐢–SS榄旀硶锛?*keystyle-Flexlayout*/.rate-container{/*杩欓噷Flex鏄痥ey*//*濡傛灉浣跨敤姝e父椤哄簭锛屽氨浣跨敤鍏勫紵鍏冪礌閫夋嫨鍣▇*//*浼氬鑷粹潳鐨勯€夋嫨琚弽杞?//*鎵€浠ラ渶瑕乫lex-direction鍐嶇炕杞竴娆?/display:flex;寮规€ф柟鍚戯細琛屽弽杞紱justify-content:center;}/*绉婚櫎榛樿鏍峰紡*/.rate{position:relative;-webkit澶栬锛氭棤锛涜竟妗嗭細鏃狅紱澶х翰锛氭棤锛涙父鏍囷細鎸囬拡锛涘搴︼細24px锛沨eight:24px;}杩欓噷鍙互鐪嬪埌鎴戜滑鍘熸潵鎸夌収5->1鎺掑簭鐨刬nput:radio缁勪欢閫氳繃display:flex灞炴€у弽杞簡鐒跺悗鎴戜滑鍦?rate涓婂幓鎺変簡榛樿鏍峰紡锛屾墍浠ョ幇鍦ㄨ竟妗嗘槸涓嶅啀鍙銆傝鎴戜滑鐢讳竴棰楀績锛岃瀹冨湪鎮仠鏃朵寒璧锋潵锛?*鐢诲績缁勪欢*/.rate::after{position:absolute;鍐呭锛?鉂?;font-size:24px;}/*鍏冪礌鎮仠鏁堟灉*/.rate:hover,/*鍏冪礌鎮仠鍚庯紝鍏勫紵鍏冪礌浼氱浉搴斿彉鍖?//*杩欓噷浣跨敤~鐩存帴鏀瑰彉鎵€鏈夊悗缁厓绱?//*濡傛灉浣犵敤+锛屽彧鏈夊悗闈㈢殑鍏冪礌浼氭敼鍙?/.rate:hover~.rate,/*閫変腑鍏冪礌鍚庯紝鍙樺寲鍚屼笂*/.rate:checked,.rate:checked~.rate{color:deeppink;}姝ゆ椂鎴戜滑鍙互鐪嬪埌锛氭槸涓嶆槸寰堢畝鍗晘杩欎釜鏈夋椂鍊欎笉鏄庣櫧.rate鐨勬剰鎬濄€傚ぇ瀹跺彲浠ュ洖椤句竴涓嬪紑澶寸殑CSS灞炴€цВ閲婄殑绗笁姝ャ€傛垜浠畬鎴怞avaScript浠g爜鐨勭紪鍐欙紝璁╁畠鐨勪氦浜掓洿鏈夎叮锛歸indow.onload=()=>{constscoring=document.querySelector('.scoring');constcheckboxList=document.querySelectorAll('.rate');//鏈€鍚庡緱鍒唋etprevScore=0;checkboxList.forEach((item)=>{//鏀瑰彉score鏃讹紝璁剧疆Texteffectitem.onchange=(e)=>{constscore=Number(e.target.value);switch(score){case1:scoring.innerText='-_-璋㈣阿浣犱笉鐪嬪ソ鎴?_-';break;case2:scoring.innerText='鍝囷紝鎴戞瘮lower濂藉浜嗭紒';break;case3:scoring.innerText='杩樼畻涓涓煩锛岄夯楹粇';break;case4:scoring.innerText='鍝囷紝鎴戞瘮楂樹竴宸簡涓€姝ワ紒';break;case5:scoring.innerText='^_^璋㈣阿浣犺繖涔堢湅濂芥垜^_^';浼戞伅;default:scoring.innerText='鎵撳垎鍟﹀皬浼欎即~';浼戞伅;}};//褰撶偣鍑绘椂锛屽垽鏂槸鍚﹂€変腑鎴栧彇娑堥€変腑item.onclick=(e)=>{constscore=Number(e.target.value);//濡傛灉鍒嗘暟鐩稿悓锛屽垯鍙栨秷閫夋嫨骞舵竻闄ゅ垎鏁癷f(score===prevScore){item.checked=false;prevScore=0;scoring.innerText='灏忎紮浼翠滑锛岃鎵撳垎~'}else{//鍚﹀垯锛岃缃笂娆″緱鍒唒revScore=score;}};});};灏辫繖鏍凤紝鎴戜滑瀹屾垚浜嗘墦鍒嗘晥鏋滐細鍥涘ぇ鍙傝€冩帢閲?SmartTom-鍚堢悊锛屽彧鏈?琛屾牳蹇僣ss鐮佺巼鎵撳垎缁勪欢锛屾垜鑷繁缁欏ご鐨湅浜嗮煓嗏€嶁檪锔廏itHub-jawil/blog-PureCSS瀹炵幇缃戠珯甯哥敤鐨勪簲瑙掓槦鎵撳垎鍙婃墦鍒嗘樉绀轰氦浜掓晥鏋滆寰楁枃绔犱笉閿欑殑鏈嬪弸娆㈣繋鐐硅禐/鐐筍tar銆傚闇€鑱旂郴jsliang锛欸ithub鎺橀噾涓汉鑱旂郴鏂瑰紡淇濆瓨鍦℅ithub涓婚〉锛屾杩庝竴璧锋姌鑵緙鍔姏鎶婅嚜宸辨墦閫犳垚涓€涓厖婊℃帰绱㈡锛屽枩娆㈡姌鑵撅紝涔愪簬鎵╁厖鐭ヨ瘑闈㈢殑浜?鏂滄潬绋嬪簭鍛樼殑缁堣韩瀛︿範銆俲sliang鐨勬枃妗e簱鐢盝unrongLiang鏍规嵁CreativeCommonsAttribution-NonCommercial-ShareAlike4.0InternationalLicense鎺堟潈銆?br/>鍩轰簬https://github.com/LiangJunrong/document-library涓婄殑浣滃搧銆?br/>闈炴湰璁稿彲鍗忚鎺堟潈鐨勪娇鐢ㄦ潈鍙粠https://creativecommons.org/licenses/by-nc-sa/2.5/cn/鑾峰彇銆?/p>