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

CSS@property,让不可能成为可能

时间:2023-03-30 15:09:48 CSS

鏈枃涓昏璁茬殑鏄疌SS鐨勪竴涓潪甯告柊鐨勭壒鎬э紝CSS@property锛屽畠鐨勫嚭鐜板ぇ澶ф彁鍗囦簡CSS鐨勮兘鍔涳紒鏍规嵁MDN--CSSProperty锛孈propertyCSSat-rule鏄疌SSHoudiniAPI鐨勪竴閮ㄥ垎锛屽畠鍏佽寮€鍙戜汉鍛樻樉寮忓畾涔変粬浠殑CSS鑷畾涔夊睘鎬э紝鍏佽灞炴€х被鍨嬫鏌ャ€佽缃粯璁ゅ€间互鍙婂畾涔夎嚜瀹氫箟灞炴€ф槸鍚﹀彲浠ョ户鎵裤€備粈涔堟槸CSS鑳¤开灏硷紵CSSHoudini鍚戝紑鍙戣€呭紑鏀句簡CSS鐨勫簳灞侫PI锛岃寮€鍙戣€呭彲浠ラ€氳繃杩欏鎺ュ彛鑷鎵╁睍CSS锛屽苟鎻愪緵鐩稿簲鐨勫伐鍏疯寮€鍙戣€呭共棰勬祻瑙堝櫒娓叉煋寮曟搸鐨勬牱寮忓拰甯冨眬杩囩▼銆傚厑璁稿紑鍙戜汉鍛樼紪鍐欐祻瑙堝櫒鍙互瑙f瀽鐨凜SS浠g爜锛屼粠鑰屽垱寤烘柊鐨凜SS鍔熻兘銆傚綋鐒讹紝杩欎笉鏄湰鏂囩殑閲嶇偣锛屼絾鎴戜笉浼氳繃澶氭弿杩般€傚浣曚娇鐢–SS灞炴€э紵鎴戜滑灏嗛€氳繃涓€浜涚畝鍗曠殑渚嬪瓙蹇€熷叆闂紝閲嶇偣浠嬬粛瀹冨湪CSS鍔ㄧ敾涓殑鍏抽敭浣滅敤锛屼互鍙婂畠缁機SS鍔ㄧ敾甯︽潵鐨勫法澶ф敼杩涖€傜ず渚嬮€氬父锛屾垜浠畾涔夊拰浣跨敤CSS鑷畾涔夊睘鎬х殑鏂瑰紡濡備笅锛?root{--whiteColor:#fff;}p{color:(--whiteColor);}閫氳繃@property瑙勫垯锛屾垜浠繕鍙互瀹氫箟CSS鑷畾涔夊睘鎬у涓嬩唬鐮侊細绠€鍗曡В閲婏細@property--property-namein--property-name鏄嚜瀹氫箟灞炴€х殑鍚嶇О锛屽湪CSS涓彲浠ラ€氳繃var(--property-name)鏉ュ畾涔夛紝鍙傝€冭娉曪細鑷畾涔夊睘鎬х殑璇硶瑙勫垯锛屼篃鍙互鐞嗚В涓鸿〃绀哄畾涔夌殑鑷畾涔夊睘鎬х殑绫诲瀷inherits锛氭槸鍚﹀厑璁哥户鎵縤nitial-value锛氬垵濮嬪€煎叾涓瑻property瑙勫垯Descriptor涓殑璇硶鍜岀户鎵挎槸蹇呴渶鐨勩€傚綋鐒禞avaScript涓畾涔夌殑鍐欐硶涔熷緢绠€鍗曪紝椤轰究璇翠竴鍙ワ細鏀寔鐨剆yntax璇硶绫诲瀷syntax鏀寔鐨勮娉曠被鍨嬮潪甯镐赴瀵岋紝鍩烘湰涓婃兜鐩栦簡浣犺兘鎯冲埌鐨勬墍鏈夌被鍨嬨€俵engthnumberpercentagelength-percentagecolorimageurlintegerangletimeresolutiontransform-listtransform-functioncustom-ident(acustomidentifierstring)鐢?銆?銆亅瀹氫箟鐨凜SS@property鍙橀噺鐨勮娉曡娉晄ymbolsinsyntax鎺ュ彈涓€浜涚壒娈婄殑绫诲瀷瀹氫箟銆傝娉曪細''锛氭帴鍙楅€楀彿鍒嗛殧鐨勯鑹插€煎垪琛ㄨ娉曪細''锛氭帴鍙楃┖鏍煎垎闅旂殑闀垮害鍊煎垪琛ㄨ娉曪細'':鎺ュ彈鍗曚釜闀垮害鎴栬€呯┖鏍煎垎闅旂殑闀垮害鍊煎垪琛ㄥ氨OK浜嗭紝閾哄灚浜嗚繖涔堝锛岄偅涓轰粈涔堣鐢ㄨ繖涔堥夯鐑︾殑璇硶鏉ュ畾涔塁SS鑷畾涔夊睘鎬у憿锛烠SSHoudini瀹氫箟鑷畾涔夊彉閲忔湁浠€涔堝ソ澶勶紵璁╂垜浠竴涓€璋堣皥銆備娇鐢ㄩ鑹茶娉曡娉曠被鍨嬩綔鐢ㄤ簬娓愬彉銆傛垜浠潵鐪嬭繖鏍蜂竴涓緥瀛愩€傛垜浠湁杩欐牱涓€涓笎鍙樻ā寮忥細

div{background:linear-gradient(45deg,#fff,#000);}鎴戜滑鍦ㄤ笂闈㈢殑浠g爜涓嬮潰锛屾敼鐢–SS鑷畾涔夊睘鎬э細:root{--棰滆壊A锛?fff锛?-colorB:#000;}div{background:linear-gradient(45deg,var(--colorA),var(--colorB));}缁撴灉浠嶇劧鏄浉鍚岀殑娓愬彉鍥惧儚锛氭垜浠坊鍔犱簡杩囨浮鏁堟灉锛氾細root{--colorA:#fff;--colorB:#000;}div{鑳屾櫙:绾挎€ф笎鍙?45deg,var(--colorA),var(--colorB));杩囨浮锛?s鑳屾櫙锛?:hover{--colorA:榛勭豢鑹?--colorB锛氭繁绮夎壊锛泒}鐪嬬湅榧犳爣鎮仠鏃朵細鍙戠敓浠€涔堬細铏界劧鎴戜滑璁剧疆浜嗕竴涓?s鐨勮繃娓″姩鐢籺ransition:1sbackground浣嗕笉骞哥殑鏄紝CSS涓嶆敮鎸佽儗鏅笎鍙樿壊鐨勭洿鎺ヨ繃娓★紝鎴戜滑寰楀埌鐨勫彧鏄袱甯т箣闂寸殑鍙樺寲銆備娇鐢–SS@property鏀归€燨K锛屾帴涓嬫潵灏辨槸鏈枃鐨勪富瑙掞紝浣跨敤HoudiniAPI涓殑CSS鑷畾涔夊睘鎬ф潵鏇挎崲鍘熸潵鐨凜SS鑷畾涔夊睘鎬с€傜畝鍗曚慨鏀癸紝浣跨敤棰滆壊璇硶syntaxtype:@property--houdini-colorA{syntax:'';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細#fff;}@property--houdini-colorB{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細#000;}.property{鑳屾櫙锛氱嚎鎬ф笎鍙橈紙45deg锛寁ar锛?-houdini-colorA锛夛紝var锛?-houdini-colorB锛夛級;杩囨浮锛?s--houdini-colorA锛?s--houdini-colorB锛?:hover{--houdini-colorA:yellowgreen;--houdini-colorB锛氭繁绮夎壊锛泒}鎴戜滑浣跨敤@property璇硶瀹氫箟浜嗕袱涓狢SSHoudini鑷畾涔夊彉閲?-houdini-colorA鍜?-houdini-colorB锛屽綋hover鍙樺寲鏃舵敼鍙樿繖涓や釜棰滆壊銆傞渶瑕佹敞鎰忕殑鏄紝鎴戜滑璁剧疆鐨則ransition璇彞鏄痶ransition:1s--houdini-colorA,1s--houdini-colorB銆傚湪杩欓噷锛屾垜浠负CSSHoudini鑷畾涔夊彉閲忚缃繃娓★紝鑰屼笉鏄负鑳屾櫙璁剧疆杩囨浮锛屾垜浠湅鐪嬭繖娆$殑鏁堟灉锛氬搰锛屾垚鍔熶簡锛屾笎鍙樿壊鐨勫彉鍖栦粠涓ゅ抚閫愬抚鍔ㄧ敾鍙樻垚浜嗚ˉ闂村姩鐢伙紝瀹炵幇浜嗕粠涓€绉嶆笎鍙樿壊杩囨浮鍒板彟涓€绉嶆笎鍙樿壊锛佽€岃繖閮借褰掑姛浜嶤SSHoudini鑷畾涔夊彉閲忕殑寮哄ぇ鑳藉姏锛丆odePenDemo--CSSHoudini鑷畾涔夊彉閲忓疄鐜版笎鍙樿壊杩囨浮鍔ㄧ敾浣跨敤CSS@property瀹炵幇娓愬彉鑳屾櫙鑹茶繃娓″姩鐢诲湪涓婇潰鐨凞EMO涓紝鎴戜滑浣跨敤CSSHoudini鑷畾涔夊彉閲忓皢鍘熸湰瀹氫箟鍦╞ackground涓殑杩囨浮鏁堟灉瀚佹帴鍒癱olor涔嬩笂涔熷氨鏄锛孋SS鏀寔灏嗕竴绉嶉鑹茶浆鎹负鍙︿竴绉嶉鑹层€傝繖鏍锋垜浠氨宸у鐨勫疄鐜颁簡娓愬彉鑳屾櫙鑹茬殑杩囨浮鍔ㄧ敾銆備箣鍓嶆垜浠璁轰簡鍦–SS涓湁澶氬皯绉嶆柟娉曞彲浠ヤ负娓愬彉鑳屾櫙棰滆壊杩囨浮璁剧疆鍔ㄧ敾鈥斺€斿阀濡欏湴璁剧疆鑳屾櫙棰滆壊娓愬彉鍔ㄧ敾锛侊紝鍒颁粖澶╀负姝紝鎴戜滑鏈変簡鍙︿竴绉嶅疄鐜版柟寮忥紒@property--colorA{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細绱孩鑹诧紱}@property--colorC{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細#f79188锛泒@property--colorF{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細绾㈣壊锛泒div{鑳屾櫙锛氱嚎鎬ф笎鍙橈紙45deg锛寁ar锛?-colorA锛夛紝var锛?-colorC锛夛紝var锛?-colorF锛夛級;鍔ㄧ敾锛氭敼鍙?0s鏃犻檺绾挎€э紱}@keyframes鏀瑰彉{20%{--colorA锛氱孩鑹诧紱--colorC:#a93ee0;--colorF锛氱传绾㈣壊锛泒40%{--colorA:#ff3c41;--colorC:#e228a0;--colorF:#2e4c96;}60%{--colorA:姗欒壊;--colorC锛氱豢鑹诧紱--colorF锛氳摑缁胯壊锛泒80%{--colorA:#ae63e4;--colorC:#0ebeff;--colorF:#efc371;}}瀹屾暣浠g爜鍙互鐐瑰嚮杩欓噷锛欳odePenDemo--CSSHoudini鑷畾涔夊彉閲忓疄鐜版笎鍙橀鑹茶繃娓″姩鐢?conic-gradient鍜孋SS@property瀹炵幇楗煎浘鍔ㄧ敾OK锛屼笂闈㈡垜浠紨绀轰簡璇硶鏄鑹茶娉曠被鍨嬬殑鎯呭喌銆傚湪鏂囩珷鐨勫紑澶达紝鎴戜滑涔熷垪涓句簡寰堝璇硶绫诲瀷銆傛帴涓嬫潵鎴戜滑璇曡瘯鍏朵粬鐨勭被鍨嬶紝鐢╬ercentage鐧惧垎姣旂被鍨嬫垨鑰卆ngle瑙掑害绫诲瀷鏉ュ疄鐜伴ゼ鍥剧殑鎮仠鍔ㄧ敾銆傚鏋滆繕鏄敤浼犵粺鐨勫啓娉曪紝鎴戜滑鍙互浣跨敤瑙掑害娓愬彉鏉ュ疄鐜颁笉鍚岃搴︾殑楗煎浘锛?div>
.normal{width:200px;楂樺害锛?00px锛涜竟鐣屽崐寰勶細50%锛涜儗鏅細鍦嗛敟娓愬彉锛堥粍缁胯壊锛岄粍缁胯壊25%锛岄€忔槑25%锛岄€忔槑100%锛夛紱杩囨浮锛氳儗鏅?0鈥嬧€?ms锛?:hover{鑳屾櫙锛氬渾閿ユ搴︼紙榛勭豢鑹诧紝榛勭豢鑹?0%锛岄€忔槑60.1%锛岄€忔槑100%锛夛紱}}浼氬緱鍒拌繖鏍风殑鏁堟灉锛岀敱浜巆onic-gradient涓嶆敮鎸佽繃娓″姩鐢伙紝寰楀埌鐨勬槸鐩存帴浠庝竴甯у埌鍙︿竴甯х殑鍙樺寲锛歄K锛屼娇鐢–SSHoudini鑷畾涔夊彉閲忚繘琛屽彉鎹細@property--per{'<鐧惧垎姣?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細25%锛泒div{鑳屾櫙锛氬渾閿ユ搴︼紙榛勭豢鑹诧紝榛勭豢鑹瞯ar锛?-per锛夛紝閫忔槑var锛?-per锛夛紝閫忔槑100%锛夛紱杩囨浮锛?-姣?00姣绾挎€э紱&:hover{--per:60%;}}鐪嬬湅鏀归€犲悗鐨勬晥鏋滐細CodePodeDemo--conic-gradientwithCSS@property瀹炵幇楗煎浘鍔ㄧ敾鐨勬晥鏋滐紝浠ュ墠鍙兘鐢ㄧ函CSS寰堝鏉傦紝濡傛灉鑳借交鏉惧疄鐜扮殑璇濓紝涓嶅緱涓嶆劅鎱–SS@property鐨勫己澶ц兘鍔涳紒椤轰究璇翠竴鍙ワ紝|symbolofsyntax鍦ㄥ畾涔塇oudini鑷畾涔夊彉閲忔椂婕旂ず浜嗕竴浜涚◢寰鏉傜殑璇硶鐢ㄦ硶銆傚湪conic-gradient涓紝鎴戜滑鍙互浣跨敤鐧惧垎姣旀垨瑙掑害浣滀负鍏抽敭瀛椼€備笂闈㈢殑DEMO涔熷彲浠ユ敼鎴愯繖鏍凤細@property--per{syntax:'|<瑙掑害>';缁ф壙锛氬亣鐨勶紱initial-value:25%;}...琛ㄧず鎴戜滑鐨勮嚜瀹氫箟灞炴€у彲浠ユ槸鐧惧垎姣斿€兼垨瑙掑害鍊笺€傞櫎浜唡symbol锛屾湁+鍜?绗﹀彿鎺ュ彈绌烘牸鍒嗛殧鍜岄€楀彿鍒嗛殧鐨勫睘鎬э紝鏈夊叴瓒g殑鍙互鑷繁璇曡瘯銆備娇鐢ㄩ暱搴︾被鍨嬫潵澶勭悊涓€浜涢暱搴﹀彉鍖栥€傛帉鎻′簡浠ヤ笂鎶€宸у悗锛屾垜浠氨鍙互鍒╃敤Houdini鐨勮嚜瀹氫箟鍙橀噺鐨勮兘鍔涙潵濉厖淇涓€浜涗箣鍓嶆棤娉曠洿鎺ヨ浆鍦虹殑鏁堟灉浜嗐€備互鍓嶆垜浠兂瀹炵幇杩欐牱涓€涓甫涓嬪垝绾跨殑Hover鏁堟灉锛歱{text-underline-offset:1px;鏂囨湰瑁呴グ绾匡細涓嬪垝绾匡紱鏂囧瓧瑁呴グ棰滆壊锛?000锛涜繃娓★細鎵€鏈?3s锛?:hover{鏂囨湰瑁呴グ棰滆壊锛氭鑹诧紱鏂囨湰涓嬪垝绾垮亸绉婚噺锛?0px锛涢鑹蹭负姗欒壊;}}鍥犱负text-underline-offset涓嶆敮鎸佽浆鍦哄姩鐢伙紝缁撴灉濡備笅锛氫娇鐢℉oudini鑷畾涔夊彉閲忓彉鎹紝灏嗚“鍑忓彉涓洪瓟娉曪細@property--offset{syntax:'';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細0锛泒div{鏂囨湰涓嬪垝绾垮亸绉婚噺锛歷ar(--offset,1px);鏂囨湰淇グ锛氫笅鍒掔嚎锛泃ransition:--offset400ms,text-decoration-color400ms;&:hover{--offset:10px;棰滆壊涓烘鑹?鏂囨湰瑁呴グ棰滆壊锛氭鑹诧紱}}鍙互鑾峰緱涓濇粦鐨勮浆鍦烘晥鏋滐細CodePenDemo-Underlineshovertransition(ChromesolutionwithHoudini)瀹炶返涓紝浣跨敤CSS@property閰嶅悎鑳屾櫙瀹炵幇灞忎繚鍔ㄧ敾鍡紝鍥犱负CSS@property鐨勫瓨鍦紝杩欓」宸ヤ綔浠ュ墠闇€瑕佸ぇ閲忕殑CSS浠g爜绐佺劧鍙樺緱瀹规槗浜嗐€傛垜浠皾璇曚娇鐢ㄥ甫鑳屾櫙鐨凜SS@property鏉ョ畝鍗曞疄鐜颁竴涓睆淇濆姩鐢汇€傛垜浠彲浠ュ緢瀹规槗鐨勯€氳繃鑳屾櫙寰楀埌杩欐牱鐨勫浘褰紝浠g爜濡備笅锛歨tml,body{width:100%;height:100%;}body{background-image:radial-gradient(circleat86%7%,rgba(40,40,40,0.04)0%,rgba(40,40,40,0.04)50%,rgba(200,200,200,0.04)50%,rgba(200,200,200,0.04)100%),radial-gradient(circleat15%16%,rgba(99,99,99,0.04)0%,rgba(99,99,99,0.04)50%,rgba(45,45,45,0.04)50%,rgba(45,45,45,0.04)100%),radial-gradient(circleat75%99%,rgba(243,243,243,0.04)0%,rgba(243,243,243,0.04)50%,rgba(37,37,37,0.04)50%,rgba(37,37,37,0.04)100%),绾挎€ф笎鍙?rgb(34,222,237),rgb(135,89,215));}鏁堟灉濡備笅锛岃繕鏄竴寮犻潤鎬佺殑鑳屾櫙鍥撅細浠ュ墠鎴戜滑鎯宠瀹冨姩璧锋潵锛屼絾鏄渶瑕佷竴瀹氱殑鍔熷か锛岀幇鍦ㄩ€氳繃css@property锛屾垜浠兂鍙樻崲涓€浜涚粏鑺傛垜浠鍔ㄧ敾鐨勫厓绱狅紝鍙互寰楀埌寰堝ソ鐨勫姩鐢绘晥鏋滐細body,html{width:100%锛涢珮搴︼細100%锛泒@property--perA{璇硶锛?<鐧惧垎姣?'锛涚户鎵匡細鍋囩殑锛涘垵濮嬪€硷細75%锛泒@property--perB{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細99%锛泒@property--perC{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細15%锛泒@property--perD{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細16%锛泒@property--perE{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細86%锛泒@property--angle{璇硶锛?';缁ф壙锛氬亣鐨勶紱鍒濆鍊硷細0deg;}body{鑳屾櫙鍥惧儚锛氬緞鍚戞笎鍙橈紙鍦嗗湪var(--perE)7%锛宺gba(40,40,40,0.04)0%,rgba(40,40,40,0.04)50%,rgba(200,200,200,0.04)50%,rgba(200,200,200,0.04)100%),radial-gradient(circleatvar(--perC)var(--perD),RGBA(99,99,99,0.04)0%,RGBA(99,99,99,0.04)50%,rgba(45,45,45,0.04)50%,rgba(45,45,45,0.04)100%),radial-gradient(circleatvar(--perA)var(--perB),rgba(243,243,243,0.04)0%,rgba(243,243,243,0.04)50%,rgba(37,37,37,0.04)50%,rgba(37,37,37,0.04)100%),绾挎€?gradient(var(--angle),rgb(34,222,237),rgb(135,89,215));鍔ㄧ敾锛氱Щ鍔?0s鏃犻檺浜ゆ浛绾挎€э紱}@keyframes绉诲姩{100%{--perA:85%;--perB:49%;--perC锛?5%锛?-perD锛?9%锛?-perE锛?0%锛?-瑙掑害锛?60搴︼紱}}鏁堟灉濡備笅锛堢敱浜嶨if涓婁紶澶у皬闄愬埗锛岄€熷害鍔犲揩浜嗭紝鎴彇浜嗕竴閮ㄥ垎锛屽彧鏄仛涓畝鍗曠殑璇存槑锛夛細鏁翠綋鏁堟灉杩樻槸涓嶉敊鐨勶紝鍙互鐐硅繖閲屾煡鐪嬪畬鏁磀emo锛欳odePenDemo--CSS@propertyPureCSSWrapperReference:CSSPropertiesandValuesAPILevel1鏈€鍚庯紝鏈枃鍒版缁撴潫銆傛垜寮曞叆浜咰SSHoudiniAPI涓殑CSS@property閮ㄥ垎锛岀敤瀹冨疄鐜颁簡涓€浜涗互寰€鏃犳硶杞绘槗瀹炵幇鐨勫姩鐢绘晥鏋溿€傚笇鏈涘浣犳湁鎵€甯姪:)鎯宠幏鍙栨渶鏈夎叮鐨凜SS璧勬枡锛屼笉瑕侀敊杩囨垜鐨勫叕浼楀彿鈥斺€攊CSS鍓嶇杞朵簨馃槃鏇村绮惧僵CSS鎶€鏈枃绔犳眹鎬诲湪鎴戠殑Github鈥斺€攊CSS锛屾寔缁笉鏂凡鏇存柊锛屾杩庣偣涓槦璁㈤槄鏀惰棌鏈変粈涔堥棶棰樻垨鑰呭缓璁彲浠ュ浜ゆ祦銆傚師鍒涙枃绔犳枃绗旀湁闄愶紝鐭ヨ瘑鍖箯銆傚鏋滄枃绔犱腑鏈変换浣曚笉鍑嗙‘鐨勫湴鏂癸紝璇峰憡璇夋垜銆?/p>