当前位置: 首页 > Web前端 > HTML

本周重点关注《State of CSS 2022》

时间:2023-03-28 10:53:53 HTML

StateofCSS2022寮曞叆鐨凜SS鐗规€с€傛瑙?022宸茬粡鏀寔鐨勭壒鎬layer瑙e喅浜嗕笟鍔′唬鐮佺殑!important闂銆備负浠€涔堜笟鍔′唬鐮侀渶瑕佷娇鐢?important鏉ヨВ鍐抽棶棰橈紵鍥犱负css鐨勪紭鍏堢骇涓庢枃浠跺0鏄庣殑鍏堝悗椤哄簭鏈夊叧锛岃€岀幇鍦ㄥぇ閲忎笟鍔¢噰鐢ㄥ姩鎬佹彃鍏ss鐨勬柟妗堬紝鎻掑叆鐨勬椂鏈轰笌js鏂囦欢鐨勫姞杞芥墽琛屾椂闂存湁鍏筹紝瀵艰嚧涓嶇ǔ瀹氶鏍间紭鍏堛€侤layer鍏佽涓氬姟瀹氫箟鏍峰紡浼樺厛绾с€傚眰瓒婇潬鍚庯紝浼樺厛绾ц秺楂樸€傛瘮濡備笅闈㈢殑渚嬪瓙锛宱verride瀹氫箟鐨勬牱寮忎紭鍏堢骇楂樹簬framework锛欯layerframework,override;@layeroverride{.title{棰滆壊锛氱櫧鑹诧紱}}@layerframework{.title{棰滆壊锛氱孩鑹诧紱}}subgridsubgrid瑙e喅浜嗙綉鏍煎祵濂楁椂锛屽瓙缃戞牸鐨勪綅缃拰杞ㄨ抗涓嶈兘瀹屽叏瀵归綈鐖剁綉鏍肩殑闂銆傚彧闇€鍦ㄥ瓙缃戞牸鏍峰紡涓畾涔変互涓嬪唴瀹癸細.sub-grid{display:grid;缃戞牸妯℃澘鍒楋細瀛愮綉鏍硷紱grid-template-rows:subgrid;}@container@container浣垮厓绱犲搷搴旂壒瀹氱殑瀹瑰櫒澶у皬銆傚湪@container鍑烘潵涔嬪墠锛屾垜浠彧鑳戒娇鐢ˊmedia鏉ュ搷搴旇澶囩殑鏁翠綋灏哄锛岃€孈container鍙互灏嗗搷搴旈檺鍒跺湪鏌愪釜DOM瀹瑰櫒涓細//璁剧疆.container瀹瑰櫒鐨刢ontainer-name涓篴bc銆俢ontainer{container-name:abc;}//鏍规嵁abc瀹瑰櫒鐨勫ぇ灏忚繘琛屽搷搴擛containerabc(max-width:200px){.text{font-size:14px;}}涓€绉嶄娇鐢ㄥ満鏅槸锛氫笉鍚?container鍏冪礌涓殑鍏冪礌鏍峰紡鍙互涓嶅悓锛屽彇鍐充簬褰撳墠.container鐨勬牱寮忋€俬wb鏀寔hwb(hue,whiteness,blackness)definecolor:.text{color:hwb(30deg0%20%);}涓変釜鍙傛暟鍒嗗埆琛ㄧず锛氳搴0-360]銆佹贩鐧芥瘮渚嬨€佹贩榛戞瘮渚?瑙掑害瀵瑰簲鑹茶疆鍦ㄤ笉鍚岃搴︾殑浣嶇疆锛屾瘡涓搴﹂兘鏈夎嚜宸辩殑棰滆壊鍊笺€傝繖涓姛鑳介潪甯搁€傚悎浠庤壊杞殑鏌愪釜浣嶇疆鐩磋鍦版寫閫変竴绉嶉鑹层€俵ch,oklch,lab,oklab,display-p3绛塴ch(lightness,chroma,hue)锛屽嵆浜害銆侀ケ鍜屽害鍜岃壊璋冿紝璇硶濡傦細.text{color:lch(50%,100,100deg);}chroma(楗卞拰搴?鏄寚棰滆壊鐨勯矞鑹崇▼搴︼紝棰滆壊瓒婇珮锛岄鑹茶秺浜紝棰滆壊瓒婁綆锛岄鑹茶秺鏆椼€傝壊鐩革紙hue锛夋槸鎸囪壊鏉垮搴旇搴︾殑棰滆壊鍊笺€俹klch(lightness,chroma,hue,alpha)锛屽嵆浜害銆侀ケ鍜屽害銆佽壊鐩稿拰閫忔槑搴︺€?text{color:oklch(59.69%0.15649.77/0.5);}鏇村缁嗚妭涓嶅啀涓€涓€鍒椾妇銆傛€讳箣锛岃壊褰╃殑琛ㄧ幇鏂瑰紡澶氱澶氭牱锛屼篃鍙互鐩镐簰杞崲銆俢olor-mix()css璇硶鏀寔鐨刴ix绫讳技浜巗ass鐨刴ix()鍑芥暟銆傚嚱鏁帮細.text{color:color-mix(insrgb,#34c9eb10%,white);}绗竴涓弬鏁颁负棰滆壊绫诲瀷锛屽hwb銆乴ch銆乴ab銆乻rgb绛夛紝绗簩涓弬鏁颁负base棰滆壊鍜岀櫨鍒嗘瘮锛岀涓変釜鍙傛暟鏄娣峰悎鐨勯鑹层€俢olor-contrast()璁╂祻瑙堝櫒鑷姩璋冩暣涓嶅悓鑳屾櫙涓婄殑鍙闂鑹层€傛崲鍙ヨ瘽璇达紝褰撹儗鏅お鏆楁椂鑷姩浣跨敤鐧借壊鏂囨湰锛屽綋鑳屾櫙澶寒鏃惰嚜鍔ㄤ娇鐢ㄩ粦鑹叉枃鏈細.text{color:color-contrast(black);}涔熸敮鎸佹洿澶氱殑鍙傛暟銆傛湁鍏宠缁嗕俊鎭紝璇峰弬闃呬娇鐢–SSColor-Contrast()绠$悊鍙闂殑璁捐绯荤粺涓婚銆傜浉瀵归鑹茶娉曞彲浠ユ牴鎹娉曠被鍨嬪湪涓€瀹氱▼搴︿笂鏀瑰彉鏌愪釜鍊硷細.text{color:hsl(fromvar(--color)hscalc(l-20%));}濡備笂锛屼緥濡傛垜浠湪hsl棰滆壊妯″紡涓嬶紝浣跨敤--color鍙橀噺灏嗗叾l锛堜寒搴︼級浜害闄嶄綆20%銆傛笎鍙樿壊鍛藉悕绌洪棿娓愬彉鑹茬幇鍦ㄤ篃鏀寔鍛藉悕绌洪棿鐨勫0鏄庯紝渚嬪锛?text{background-image:linear-gradient(torightinhsl,black,white);}杩欐槸涓轰簡瑙e喅涓€涓彨鍋氱伆鑹叉鍖虹殑闂锛屽嵆濡傛灉娓愬彉鑹茬粡杩囬ケ鍜屽害涓?鐨勫尯鍩燂紝涓棿浼氭湁涓€娈电伆鑹诧紝鎸囧畾hsl绛夊懡鍚嶇┖闂村悗鍙互缁曡繃鐏拌壊姝诲尯銆傚洜涓篽sl瀵瑰簲鑹茶疆锛屾墍浠ユ笎鍙樼殑閫昏緫鏄部鐫€鍦嗗姬鐨勬柟鍚戠粫鑹茶疆锛岃€屼笉鏄洿鎺ラ€氳繃鍦嗗績锛堝渾蹇冮ケ鍜屽害浣庯紝浼氬憟鐜扮伆鑹诧級銆俛ccent-coloraccent-color涓昏瀵瑰崟閫夈€佸閫夈€佽繘搴︽潯绛夊師鐢熻緭鍏ョ粍浠舵湁鏁堬紝鎺у埗瀹冧滑鐨勪富棰樿壊锛歜ody{accent-color:red;}姣斿杩欐牱璁剧疆鍚庯紝鍗曢€夊拰澶氶€夌殑鑳屾櫙棰滆壊浼氱浉搴斿彉鍖栵紝杩涘害鏉$殑妯潯鍜屼腑蹇冮鑹蹭篃浼氱浉搴斿彉鍖栥€俰nertinert鏄竴涓睘鎬э紝鍙互浣垮叿鏈夎灞炴€х殑dom鍙婂叾瀛愬厓绱犱笉鍙闂紝鍗充笉鑳借鐐瑰嚮銆侀€変腑銆佸揩鎹烽敭閫変腑锛?divinert>...

COLRv1FontsCOLRv1Fonts鏄竴涓嚜瀹氫箟棰滆壊鏍峰紡鐨勭煝閲忓瓧浣撴柟妗堬紝娴忚鍣ㄦ敮鎸佽鍔熻兘锛屼娇鐢ㄦ柟娉曞涓嬶細@importurl(https://fonts.googleapis.com/css2?family=Bungee+Spice);@font-palette-鍊?-colorized{font-family:"BungeeSpice";鍩烘湰璋冭壊鏉匡細0锛沷verride-colors:0hotpink,1cyan,2white;}.spicy{font-family:鈥淏ungeeSpice鈥?font-palette:--colorized;}鍦ㄤ笂闈㈢殑渚嬪瓙涓紝鎴戜滑瀵煎叆浜嗙煝閲忓瓧浣撴枃浠讹紝閫氳繃@font-palette-values鑷畾涔変簡涓€涓悕涓篶olorized鐨勮皟鑹叉澘--colorized銆傝璋冭壊鏉块€氳繃base-palette瀹氫箟鍏剁户鎵匡細0绗竴涓唴缃皟鑹叉澘銆傞櫎浜唂ont-family锛岃繕闇€瑕佸畾涔塮ont-palette鏉ユ寚瀹氫娇鐢ㄥ摢涓猵alette锛屾瘮濡備笂闈㈠畾涔夌殑--colorized銆傞櫎浜唙h銆乿w绛夛紝瑙嗗彛鍗曞厓杩樻彁渚涗簡dvh銆乴vh銆乻vh銆備富瑕佸尯鍒湪浜庣Щ鍔ㄨ澶囦笂锛歞vh锛氬姩鎬乿h锛岃〃绀哄唴瀹圭殑楂樺害锛屼細鑷姩蹇界暐娴忚鍣ㄥ鑸爮鐨勯珮搴︺€俵vh锛氬ぇvh锛屾渶澶ч珮搴︼紝鍖呮嫭娴忚鍣ㄥ鑸爮楂樺害銆俿vh锛歴mallvh锛屾渶灏忛珮搴︼紝涓嶅寘鎷祻瑙堝櫒瀵艰埅鏍忛珮搴︺€?has()鍙互鐢ㄦ潵琛ㄧず涓€涓埗鍏冪礌鏈変竴浜涘瓙鍏冪礌锛?parent:has(.child){}琛ㄧず閫夋嫨閭d簺鏈夋湁鐢ㄧ殑.child瀛愯妭鐐圭殑.parent鑺傜偣銆傚嵆灏嗘敮鎸佺殑鐗规€scope鍙互灏嗕竴瀹氳寖鍥村唴鐨勬牱寮忎笌澶栫晫闅旂锛屼笉浼氱户鎵垮閮ㄦ牱寮忥細@scope(.card){header{color:var(--text);}}缁忚繃涓婇潰鐨勫畾涔夛紝閲岄潰鐨?card澶村厓绱犳牱寮忓氨纭畾浜嗭紝涓嶄細鍙楀埌澶栫晫鐨勫奖鍝嶃€傚鏋滄垜浠娇鐢?card{header{}}鏉ュ畾涔夋牱寮忥紝鍏ㄥ眬header{}鏍峰紡瀹氫箟鍙兘浠嶇劧浼氳鐩栧畠銆侰SSbuilt-in鍦ㄦ牱寮忓祵濂桜nestproposal鏃舵敮鎸佸祵濂楋紝灏卞儚postcss涓€鏍凤細.parent{&:hover{//...}}prefers-reduced-data@media娣诲姞prefers-reduced-data锛屾潵鎻忚堪鐢ㄦ埛鐨勮祫婧愬崰鐢ㄧ殑棰勬湡锛屾瘮濡俻refers-reduced-data:reduce琛ㄧず棰勮鍙崰鐢ㄥ皯閲忕殑缃戠粶甯﹀锛岄偅涔堟垜浠彲浠ュ湪杩欑鎯呭喌涓嬮殣钘忔墍鏈夌殑鍥剧墖鍜岃棰戯細@media(prefers-reduced-data:鍑忓皯锛墈鍥剧墖锛岃棰憑鏄剧ず锛氭棤锛泒}reduce鐨勬儏鍐典笅涔熷彲浠ラ檷浣庡浘鐗囪川閲忋€傝嚦浜庡帇缂╁灏戯紝瑕佺湅涓氬姟銆侰ustommedianame鍏佽缁橜media涓€涓嚜瀹氫箟鐨勫悕瀛楋紝寰堝鑷畾涔夌殑@media瀹氫箟濡備笅锛欯custom-media--OSdark(prefers-color-scheme:dark);@custom-media--OSlight(prefers-color-scheme:light);@custom-media--pointer(hover)and(pointer:coarse);@custom-media--mouse(hover)and(pointer:fine);@custom-media--xxs-and-浠ヤ笂锛堝搴?=240px锛夛紱@custom-media--xxs-and-below锛堝搴?=240px锛夛紱鎴戜滑鍙互鏍规嵁鑷畾涔夊悕绉颁娇鐢ㄥ畠锛欯media(--OSdark){:root{鈥}濯掍綋鑼冨洿鎻忚堪鏀寔琛ㄨ揪寮忋€備互鍓嶏紝@media(min-width:320px)鍙兘鐢ㄦ潵鎻忚堪涓嶅皬浜庢煇涓€肩殑瀹藉害銆傜幇鍦ㄥ彲浠ヤ娇鐢ˊmedia(width>=320px)浠f浛銆侤property@property鍏佽鎵╁睍css鍙橀噺骞舵弿杩颁竴浜涗慨楗扮锛欯property--x{syntax:"";鍒濆鍊硷細0px锛沬nherits:false;}涓婇潰鐨勪緥瀛愬畾涔変簡鍙橀噺x涓洪暱搴︾被鍨嬶紝鎵€浠ュ鏋滃瓧绗︿覆绫诲瀷璧嬪€奸敊璇紝灏变細浣跨敤瀹冪殑initial-value銆俿croll-startscroll-start鍏佽瀹氫箟涓€涓鍣ㄤ粠鏌愪釜浣嶇疆寮€濮嬫粴鍔細.snap-scroll-y{scroll-start-y:var(--nav-height);}:snapped:snapped杩欎釜浼被鍙互閫夋嫨褰撳墠婊氬姩瀹瑰櫒涓殑鍝嶅簲鍏冪礌锛?card:snapped{--shadow-distance:30px;}杩欎釜鍔熻兘鏈夌偣鍍廔OS鐨剆elect鎺т欢銆備笂涓嬫粦鍔ㄥ悗锛屽畠鍍忓乏杞墜鏋竴鏍疯浆鍔ㄥ厓绱狅紝鏈€鍚庡仠鐣欏湪鏌愪釜鍏冪礌涓婏紝璇ュ厓绱犲浜?snapped鐘舵€併€傚悓鏃讹紝JS杩樻敮鎸佷袱绉嶄簨浠剁被鍨嬶紝snapchanging鍜宻napchanged銆?toggle()鍙湁涓€浜涘唴缃殑html鍏冪礌鏈変竴涓?checked鐘舵€侊紝:toggle鎻愯鏄敤瀹冩潵灏嗚繖涓姸鎬佹墿灞曞埌姣忎釜鑷畾涔夊厓绱狅細button{toggle-trigger:lightswitch;}button::before{content:"馃寶";}html:toggle(lightswitch)button::before{content:"馃対";}涓婇潰鐨勪緥瀛愬畾涔変簡鎸夐挳浣滀负lightswitch鐨勮Е鍙戝櫒锛屽苟瀹氫箟浜唋ightswitch鏄惁瑙﹀彂鏃剁殑css鏍峰紡锛屾墍浠ュ嵆鍙互瀹炵幇鐐瑰嚮鎸夐挳鍦ㄩ粦鑴稿拰榛勮劯涔嬮棿鍒囨崲銆俛nchor()anchor()鍙互涓烘病鏈夌埗瀛愬叧绯荤殑鍏冪礌寤虹珛鐩稿浣嶇疆鍏崇郴銆傛洿璇︾粏鐨勪娇鐢ㄦ柟娉曪紝鍙傝CSSAnchoredPositioning銆俿electmenuselectmenu鍏佽娣诲姞浠讳綍鍏冪礌浣滀负閫夋嫨閫夐」锛?selectmenu>杩樻敮鎸佹洿澶嶆潅鐨勮娉曪紝渚嬪鍒嗙粍涓嬫媺鍒楄〃锛?selectmenuclass="my-custom-select">Chooseaplant

鑺?/h3>

鏍戞湪
姒傝CSS2022鐨勬柊鐗规€у緢澶т竴閮ㄥ垎鏄毚闇睭TML鐨勫師鐢熻兘鍔涳紝瀹炵幇涓氬姟瀹氬埗鍖栥€備絾鏄紝濡傛灉杩欎簺鐘舵€佸畬鍏ㄧ敱涓氬姟瀹炵幇锛屾瘮濡侫ntd