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

浅谈逻辑选择器——父选择器来了!

时间:2023-03-28 20:02:03 HTML

CSS閫夋嫨鍣ㄥ鏃忎腑锛屾柊澧炰簡涓€绫绘瘮杈冩柊鐨勯€夋嫨鍣ㄢ€斺€旈€昏緫閫夋嫨鍣ㄣ€傜洰鍓嶆湁4涓垚鍛橈細:is:where:not:has鏈枃灏嗗甫浣犱簡瑙e拰鍔犳繁浠栦滑銆傚簲鐢ㄦ墍瀛︾煡璇嗗苟缂栧啓鏇寸幇浠g殑閫夋嫨鍣ㄣ€?is浼被閫夋嫨鍣?is()CSS浼被鍑芥暟灏嗛€夋嫨鍣ㄥ垪琛ㄤ綔涓哄弬鏁帮紝骞堕€夋嫨鍙敱鍒楄〃涓殑浠讳綍涓€涓€夋嫨鍣ㄩ€夋嫨鐨勫厓绱犮€備互寰€瀵逛簬澶氫釜涓嶅悓鐖跺鍣ㄧ殑鍚屼竴涓瓙鍏冪礌鐨勪竴浜涢€氱敤鏍峰紡璁剧疆锛屽彲鑳戒細鍑虹幇濡備笅CSS浠g爜锛歨eaderp:hover,mainp:hover,footerp:hover{color:red;cursor:pointer;}鐜板湪鏈変簡:is()浼被锛屼笂闈㈢殑浠g爜鍙互閲嶅啓涓猴細:is(header,main,footer)p:hover{color:red;cursor:pointer;}瀹冨苟娌℃湁瀹炵幇閫夋嫨鍣ㄧ殑鏂板姛鑳斤紝鏇村儚鏄竴涓娉曠硸锛岀被浼间簬JavaScriptES6涓殑Class()璇硶锛屽彧鏄鍘熸湁鍔熻兘鐨勯噸鏂板寘瑁呰璁★紝鏇存槗浜庤〃杈句竴绉嶆搷浣滆娉曪紝绠€鍖栦簡涓€浜涘鏉備唬鐮佺殑缂栧啓銆傚彞娉曠硸鏄寚鍦ㄧ紪绋嬭瑷€涓兘澶熸洿瀹规槗鍦拌〃杈句竴涓搷浣滅殑鏂囨硶銆傚畠鍙互璁╃▼搴忓憳鏇村鏄撲娇鐢ㄨ瑷€锛屾搷浣滃彲浠ュ彉寰楁洿娓呮櫚銆佹洿鏂逛究锛屾垨鑰呰鏇寸鍚堢▼搴忓憳鐨勭紪绋嬨€備範鎯€傛瘮杈冮€氫織鏄撴噦鐨勭悊瑙e氨鏄湪浠ュ墠鐨勮娉曞熀纭€涓婃崲涓€绉嶅啓娉曪紝瀹炵幇鍚屾牱鐨勫姛鑳斤紝鍙槸鍐欐硶涓嶅悓锛屼富瑕佹槸涓轰簡璁╁紑鍙戣€呭湪浣跨敤杩囩▼涓洿瀹规槗鐞嗚В銆?涓€鍥捐儨搴忥紙鍙傝€僋ewCSS鍑芥暟寮忎吉绫婚€夋嫨鍣?is()鍜?where()锛夛細鏀寔澶氬眰绾ц仈銆傛垜浠潵鐪嬬湅杩欎釜鎯呭喌銆傚師濮婥SS浠g爜濡備笅锛?div>divi

pi

divspan

p璺ㄥ害

h1璺ㄥ害

h1i

濡傛灉瑕佸皢涓婇潰鐨凥TML锛?div>鍜?p>涓嬬殑鍜?i>鐨勯鑹茶缃负绾㈣壊锛屾甯哥殑CSS鍙兘鏄繖鏍风殑锛歞ivspan,divi,pspan,pi{color:red;}鍔犱笂:is()锛屼唬鐮佸彲浠ョ畝鍖栦负锛?is(div,p):is(span,i){color:red;}缁撴灉濡備笅锛氳繖閲岋紝杩樻敮鎸?is()鐨勭骇鑱斾娇鐢ㄣ€傞€氳繃:is(div,p):is(span,i)鐨勬帓鍒楃粍鍚堬紝鍙互缁勫悎涓婇潰4琛岀殑閫夋嫨鍣紝杈惧埌鍚屾牱鐨勬晥鏋溿€傚綋鐒惰繖涓緥瀛愭瘮杈冪畝鍗曪紝鐪嬩笉鍑?is()鐨勫▉鍔涖€備笅闈㈣繖涓緥瀛愭瘮杈冩槑鏄撅紝绫讳技CSS閫夋嫨鍣ㄤ唬鐮侊細ololul,olulul,olmenuul,olul,ololmenu,olulmenu,olmenumenu,oldirmenu,ollordir,ol鑿滃崟鑿滃崟鑿滃崟鑿滃崟鑿滃崟鑿滃崟鑿滃崟鑿滃崟鑿滃崟ulul鑿滃崟ul鑿滃崟ul鑿滃崟ul鑿滃崟menudirmenumenudirmenudirirdirmenudirdirdirdir{list-style-type:square;}鍙互浣跨敤:is()浼樺寲::is(ol,ul,menu,dir):is(ol,ul,menu,dir):is(ul,menu,dir){list-style-type:square;}鍏冪礌銆傚濡傦細鎵嬫満锛岃瘽涓嶆敮鎸佷吉鍏冪礌锛屼吉绫伙紝濡傦細鐒︾偣銆侊細鎮仠銆俤ivp::before,divp::after{鍐呭锛氣€溾€濓紱//...}涓嶈兘鍐欐垚锛歞ivp:is(::before,::after){content:"";//...}:is閫夋嫨鍣ㄧ殑浼樺厛绾х湅杩欐牱涓€涓湁瓒g殑鎯呭喌锛?div>where&istest

where&istest

鎴戜滑涓哄厓绱犺缃粯璁ら鑹?test-class:div.test-class{color:red;}濡傛灉锛屾鏃舵垜浠紩鍏?is()杩涜鍖归厤锛歞iv:is(p){color:blue;}姝ゆ椂锛岀敱浜巇iv:is(p)鍙互鐪嬪仛鏄痙ivp锛屾墍浠ヤ紭鍏堢骇涓簄odiv.test-class寰堥珮锛屾墍浠ラ€変腑鏂囨湰鐨勯鑹蹭笉浼氭敼鍙樸€備絾鏄紝濡傛灉鎴戜滑鍦?is()閫夋嫨鍣ㄤ腑娣诲姞涓€涓?test-id锛屾儏鍐靛氨涓嶅悓浜嗐€俤iv:is(p,#text-id){color:blue;}鏍规嵁鎴戠殑鐞嗚В锛屽鏋滃皢涓婇潰鐨勯€夋嫨鍣ㄦ媶鍒嗭紝涓婇潰鐨勪唬鐮佸彲浠ユ媶鍒嗕负锛歞ivp{color:blue;}div#text-id{color:blue;}閭d箞锛屾垜浠湁鐞嗙敱鐚滄祴鏄甫鏈?text-id鐨?p>鍏冪礌鏈夋洿楂樹紭鍏堢骇鐨勯€夋嫨鍣紝棰滆壊浼氬彉鎴愯摑鑹诧紝鑰屽彟涓€涓猟ivp涓嶅楂樺鑷寸涓€涓棶棰樹竴娈垫枃瀛椾粛鐒舵槸缁胯壊鐨勩€備絾鏄湪杩欓噷锛岀濂囩殑鏄紝涓ゆ潯鏂囨湰閮藉彉鎴愪簡钃濊壊锛欳odePenDemo--CSS:is閫夋嫨鍣ㄧ殑鐗规畩鎬ц繖鏄洜涓?is()鐨勪紭鍏堢骇鏄敱閫夋嫨鍣ㄧ‘瀹氱殑鍏堕€夋嫨鍣ㄥ垪琛ㄤ腑鐨勬渶楂樹紭鍏堢骇銆傛垜浠笉鑳藉垎寮€鏉ョ湅銆傚浜巇iv:is(p,#text-id)锛宨s:()閲岄潰鏈変竴涓猧d閫夋嫨鍣紝鎵€浠ユ墍鏈夌鍚堣繖涓鍒欑殑鍏冪礌閮戒細搴旂敤div#id绾у埆鐨勯€夋嫨鍣ㄤ紭鍏堢骇銆傝繖鍦ㄨ繖閲岄潪甯搁噸瑕併€傚啀寮鸿皟涓€涓嬶紝瀵逛簬:is()閫夋嫨鍣ㄧ殑浼樺厛绾э紝鎴戜滑鏄笉鑳藉垎寮€鐨勩€傚畠浠槸涓€涓暣浣擄紝浼樺厛绾у彇鍐充簬閫夋嫨鍣ㄥ垪琛ㄤ腑浼樺厛绾ф渶楂樼殑閫夋嫨鍣ㄣ€?is:matches()鍜?any():is()鐨勫埆鍚嶆槸鏈€鏂扮殑瑙勮寖鍚嶇О銆備箣鍓嶆湁鐩稿悓鍔熻兘鐨勯€夐」锛屽垎鍒槸锛?is(div,p)span{}//绛変环浜庯細-webkit-any(div,p)span{}:-moz-any(div,p)span{}:matches(div,p)span{}褰撶劧涓嬮潰涓変釜宸茬粡搴熷純浜嗭紝涓嶅缓璁户缁娇鐢ㄣ€傝€屼粖澶╋紙2022-04-27锛夛細:is()鐨勫吋瀹规€у凡缁忓緢濂戒簡銆傚鏋滀笉闇€瑕佸吋瀹笽E绯诲垪锛屽彲浠ヨ€冭檻寮€濮嬩娇鐢紙withautoprefixer锛夈€傜湅涓€涓婥anIUse::where浼被閫夋嫨鍣ㄦ潵鐞嗚В:is涔嬪悗锛屾垜浠彲浠ュ啀鐪嬩竴涓?where锛屽畠浠袱涓槸闈炲父寮虹浉鍏崇殑銆?where鍚屾牱灏嗛€夋嫨鍣ㄥ垪琛ㄤ綔涓哄叾鍙傛暟锛屽苟閫夋嫨鍙敱璇ュ垪琛ㄤ腑鐨勪竴涓€夋嫨鍣ㄩ€夋嫨鐨勪换浣曞厓绱犮€傝繕鏄繖涓緥瀛愶細:where(header,main,footer)p:hover{color:red;cursor:pointer;}涓婇潰浠g爜浣跨敤浜?where锛屽彲浠ヨ繎浼间负锛歨eaderp:hover,mainp:hover,footerp:hover{color:red;cursor:pointer;}杩欏緢鏈夎叮锛岃繖涓嶆槸鍜屼笂闈㈣鐨?涓€鏍峰悧锛熼偅涔堝畠浠箣闂存湁浠€涔堝尯鍒憿锛?is鍜?where鐨勫尯鍒鍏堬紝浠庤娉曚笂鏉ヨ锛?is鍜?where鏄畬鍏ㄤ竴鏍风殑銆傚畠浠箣闂寸殑鏍稿績鍖哄埆鏄紭鍏堢骇銆傛垜浠潵鐪嬭繖鏍蜂竴涓緥瀛愶細

where&istest

CSS浠g爜濡備笅锛?is(div)p{color:red;}:where(div)p{color:green;}閫氬父锛屾寜鐓ф垜浠殑鐞嗚В锛?is(div)p鍜?where(div)p閮藉彲浠ヨ浆鍖栦负divp銆傜敱浜?where(div)p鏄悗闈㈠畾涔夌殑锛屾墍浠ユ枃鏈殑棰滆壊搴旇鏄豢鑹层€備絾鏄紝瀹為檯棰滆壊鏄剧ず涓篶olor:redred:杩欐槸鍥犱负:where()鍜?is()鐨勫尯鍒湪浜?where()鐨勪紭鍏堢骇濮嬬粓涓?锛岃€?is()鐨勪紭鍏堢骇涓篈绫荤敱鍏堕€夋嫨鍣ㄥ垪琛ㄤ腑浼樺厛绾ф渶楂樼殑閫夋嫨鍣ㄧ‘瀹氥€備笂闈㈢殑渚嬪瓙涓嶆槸鐗瑰埆鏄庢樉锛屾垜浠◢寰慨鏀逛竴涓嬶細CSS浠g爜::is(div)p{color:red;}:where(#container)p{color:green;}鍗充究濡傛锛岀敱浜?where(#container)鐨勪紭鍏堢骇涓?锛屾墍浠ユ枃鏈殑棰滆壊鏄繕鏄孩绾㈢殑銆?where()濮嬬粓鍏锋湁0鐨勪紭鍏堢骇锛岃繖鏄娇鐢ㄥ畠鏃惰璁颁綇鐨勪簨鎯呫€傜粍鍚堜笌宓屽CSS閫夋嫨鍣ㄧ殑涓€涓潪甯稿ぇ鐨勭壒鐐瑰氨鏄粍鍚堜笌宓屽銆?is鍜?where涔熶笉渚嬪锛屾墍浠ュ畠浠篃鍙互鐩镐簰缁勫悎鍜屽祵濂椼€備互涓婥SS閫夋嫨鍣ㄩ兘鏄悎鐞嗙殑锛?*combination*/:is(h1,h2):where(.test-a,.test-b){text-transform:uppercase;}/*nested*/.title:where(h1,h2,:is(.header,.footer)){font-weight:bold;}杩欓噷绠€鍗曟€荤粨涓?is鍜?where閮芥槸寰堝ソ鐨勫垎缁勯€昏緫閫夋嫨鍣紝鍞竴涓嶅悓鐨勬槸浼樺厛绾?where()鐨勪紭鍏堢骇濮嬬粓涓?锛岃€?is()鐨勪紭鍏堢骇鐢卞叾閫夋嫨鍣ㄥ垪琛ㄥ喅瀹氫紭鍏堢骇鐢辨渶楂樼骇鍒殑閫夋嫨鍣ㄥ喅瀹氥€?not浼被閫夋嫨鍣ㄤ笅闈粙缁嶄竴涓潪甯告湁鐢ㄧ殑:not浼被閫夋嫨鍣ㄣ€?not浼€夋嫨鍣ㄧ敤浜庡尮閰嶄笉鍖归厤涓€缁勯€夋嫨鍣ㄧ殑鍏冪礌銆傜敱浜庡畠鐨勪綔鐢ㄦ槸闃叉鐗瑰畾鍏冪礌琚€変腑锛屾墍浠ュ畠涔熻绉颁负鍚﹀畾浼被銆備緥濡傦紝HTML缁撴瀯濡備笅锛?divclass="a">div.a
div.b
div銆俢div.ddiv:not(.b){color:red;}div:not(.b)鍙互閫夋嫨绫讳互澶栫殑鍏冪礌涓?b鎵€鏈塪iv鍏冪礌锛歁DN涓婄殑閿欒绀轰緥锛熶竴涓湁瓒g殑鐜拌薄鏄湪浠嬬粛:not鐨凪DN椤甸潰涓婏紝鏈夎繖鏍蜂竴涓緥瀛愶細/*SelectsanyelementthatisNOTaparagraph*/:not(p){color:blue;}鎰忔€濇槸锛?not(p)閫夋嫨浠讳綍涓嶆槸

鏍囩鐨勫厓绱犮€備絾鏄紝涓婇潰鐨凜SS閫夋嫨鍣紝鍦ㄤ笅闈㈢殑HTML缁撴瀯涓紝娴嬪嚭鏉ョ殑缁撴灉涓嶅お瀵广€?p>p

div
span

h1

缁撴灉濡備笅锛氳〃绀猴紝:not(p)浠嶇劧鍙互閫変腑

鍏冪礌銆傛垜璇曡繃澶氫釜娴忚鍣紝缁撴灉閮芥槸涓€鏍风殑銆侰odePenDemo--:notpesudodemo涓轰粈涔堬紵杩欐槸鍥犱负锛歯ot(p)涔熷彲浠ラ€変腑锛岄偅涔?body>鐨勯鑹插氨鍙樻垚浜嗚摑鑹层€傜敱浜庨鑹叉槸鍙户鎵跨殑灞炴€э紝

鏍囩缁ф壙浜?body>鐨勯鑹插睘鎬э紝瀵艰嚧

涔熸槸钃濊壊鐨勩€傝鎴戜滑鎶婂畠鏀规垚涓€涓笉鍙户鎵跨殑灞炴€э紝璇曡瘯鐪嬶細/*SelectsanyelementthatisNOTaparagraph*/:not(p){border:1pxsolid;}OK锛岃繖娆?p>娌℃湁杈规锛屾病闂锛佸湪瀹為檯浣跨敤涓紝闇€瑕佹敞鎰忚繖灞傜户鎵跨殑闂锛?not鐨勪紭鍏堢骇闂浠ヤ笅鏄娇鐢?not鏃堕渶瑕佹敞鎰忕殑涓€浜涢棶棰樸€?not,:is,:where杩欎簺浼被涓嶅儚鍏朵粬浼被锛屽畠涓嶄細澧炲姞閫夋嫨鍣ㄧ殑浼樺厛绾с€傚畠鐨勪紭鍏堢骇鏄畠鐨勫弬鏁伴€夋嫨鍣ㄧ殑浼樺厛绾с€傚彟澶栵紝鍦–SSSelectorsLevel3涓紝:not()鍐呴儴鍙敮鎸佸崟涓€夋嫨鍣紝浠嶤SSSelectorsLevel4寮€濮嬶紝:not()鍐呴儴鏀寔澶氫釜閫夋嫨鍣紝鍍忚繖鏍凤細/*CSSSelectorsLevel3,:not濡傛灉閲岄潰鏈夊涓€硷紝闇€瑕佸垎闅?/p:not(:first-of-type):not(.special){}/*CSSSelectorsLevel4鏀寔閫楀彿鍒嗛殧*/p:not(:first-of-type,.special){}涓?is()绫讳技锛?not()閫夋嫨鍣ㄦ湰韬笉褰卞搷閫夋嫨鍣ㄧ殑浼樺厛绾э紝鍏朵紭鍏堢骇鐢卞叾閫夋嫨鍣ㄥ垪琛ㄤ腑浼樺厛绾ф渶楂樼殑閫夋嫨鍣ㄥ喅瀹氥€?not(*)闂浣跨敤:not(*)灏嗗尮閰嶄换浣曚笉鏄厓绱犵殑鍏冪礌锛屽洜姝ゆ案杩滀笉浼氬簲鐢ㄦ瑙勫垯銆傜浉褰撲簬涓€娈垫病鏈変换浣曟剰涔夌殑浠g爜銆?not()涓嶈兘宓屽:not()绂佹宓屽濞冨▋銆?not浼被涓嶅厑璁稿祵濂楋紝杩欐剰鍛崇潃:not(:not(...))鏄棤鏁堢殑銆?not()瀹炴垬鍒嗘瀽閭d箞锛?not()鏈夊摢浜涚壒鍒湁瓒g殑搴旂敤鍦烘櫙鍛紵鎴戝湪杩欓噷鍒楀嚭涓€涓€傚湪W3CSSselectors-4瑙勮寖涓紝娣诲姞浜嗕竴涓潪甯告湁瓒g殑:focus-visible浼被銆?focus-visible姝ら€夋嫨鍣ㄥ彲鐢ㄤ簬鏍规嵁鐢ㄦ埛鐨勮緭鍏ユ柟娉曪紙榧犳爣涓庨敭鐩橈級鏄剧ず涓嶅悓褰㈠紡鐨勭劍鐐广€傛湁浜嗚繖涓吉绫伙紝灏卞彲浠ユ悶瀹氫簡銆傚綋鐢ㄦ埛浣跨敤榧犳爣鎿嶄綔鍙幏寰楃劍鐐圭殑鍏冪礌鏃讹紝:focus鏍峰紡涓嶆樉绀烘垨鎬ц兘杈冨急銆傚綋鐢ㄦ埛浣跨敤閿洏鎿嶄綔鐒︾偣鏃讹紝浣跨敤:focus-visible鍙互璁╃劍鐐瑰厓绱犺幏寰楁洿寮虹殑鍛堢幇椋庢牸銆傜湅涓€涓畝鍗曠殑demo锛?button>Test1button:active{background:#eee;}button:focus{outline:2pxsolidred;}鐢ㄩ紶鏍囩偣鍑伙細浣犲彲浠ョ湅鍒板綋浣犵偣鍑籱ouse,瑙﹀彂浜嗗厓绱犵殑:active浼被锛屽悓鏃惰Е鍙戜簡:focus浼被锛屼笉澶編瑙傘€備絾鏄鏋滆缃畂utline:none锛屼細璁╅敭鐩樼敤鎴风殑浣撻獙寰堝樊銆傚洜涓哄綋閿洏鐢ㄦ埛浣跨敤Tab灏濊瘯鍒囨崲鐒︾偣鏃讹紝浼氬洜涓簅utline:none鑰屾墜瓒虫棤鎺€傚洜姝わ紝鍙互浣跨敤:focus-visible浼被瀵瑰叾杩涜淇グ锛歜utton:active{background:#eee;}button:focus{outline:2pxsolidred;}button:focus:not(:focus-visible){澶х翰锛氭棤锛泒鐪嬫晥鏋滐紝鍒嗗埆鐢ㄩ紶鏍囩偣鍑籅utton鍜岄敭鐩樼偣鍑籅utton鎺у埗鐒︾偣锛欳odePenDemo--:focus-visibleexample鍙互鐪嬪埌浣跨敤榧犳爣鐐瑰嚮涓嶄細瑙﹀彂:foucs锛屽彧鏈夊綋閿洏鎿嶄綔鐒︾偣鍏冪礌锛屼娇鐢╫utline:2pxsolidred浠g爜鍙細鍦═ab鍒囨崲鐒︾偣鏃剁敓鏁堛€傝繖鏍锋棦淇濊瘉浜嗘甯哥敤鎴风殑鐐瑰嚮浣撻獙锛屽張淇濊瘉浜嗘棤娉曚娇鐢ㄩ紶鏍囩殑鐢ㄦ埛鐨勭劍鐐圭鐞嗕綋楠岋紝鍦ㄦ棤闅滅涓婁笅浜嗗姛澶€傚€煎緱娉ㄦ剰鐨勬槸杩欓噷涓轰粈涔堜娇鐢╞utton:focus:not(:focus-visible)鑰屼笉鏄洿鎺ヨ繖鏍峰啓锛歜utton:focus{outline:unset;}button:focus-visible{outline:2pxsolidred;}瑙i噴涓€涓嬶紝button:focus:not(:focus-visible)琛ㄧずbutton鍏冪礌瑙﹀彂focus鐘舵€侊紝涓嶆槸focus-visible瑙﹀彂鐨勩€傛嵁浜嗚В锛屾槸鏀寔:focus-visible鐨勬祻瑙堝櫒锛岄€氳繃榧犳爣鍦╞utton鍏冪礌涓婃縺娲?focus锛岃繖鏍峰氨涓嶉渶瑕乷utline浜嗐€備负浜嗗吋瀹逛笉鏀寔:focus-visible鐨勬祻瑙堝櫒锛屽綋:focus-visible涓嶅吋瀹规椂锛屼粛鐒堕渶瑕?focus浼被鐨勫瓨鍦ㄣ€傚洜姝わ紝杩欓噷鍊熷姪浜?not()浼被锛屽阀濡欑殑瀹炵幇浜嗕竴涓疄鐢ㄧ殑闄嶇骇銆傝繖閲岃鐨勬湁鐐圭粫锛岄渶瑕佺悊瑙g悊瑙c€?not鍏煎鎬х粡鍘嗕簡CSSSelectorsLevel3&CSSSelectorsLevel4涓や釜鐗堟湰锛屾埅姝㈠埌浠婂ぉ锛?020-05-04锛夛紝闄や簡IE绯诲垪锛?not鐨勫吋瀹规€у凡缁忓緢濂戒簡::haspseudo-绫婚€夋嫨鍣ㄧ‘瀹氥€傛渶鍚庯紝鎵€鏈夐€昏緫閫夋嫨鍣ㄤ腑鏈€閲嶈鐨?has寮€濮嬪彂鎸ヤ綔鐢ㄣ€備箣鎵€浠ラ噸瑕侊紝鏄洜涓哄畠鐨勮癁鐢熸槸涓轰簡濉ˉ浠ュ線CSS閫夋嫨鍣ㄤ腑娌℃湁鏍稿績鎰忎箟涓婄湡姝g殑鐖堕€夋嫨鍣ㄧ殑绌虹己銆?has浼被鎺ュ彈涓€涓€夋嫨鍣ㄧ粍浣滀负鍙傛暟锛岃閫夋嫨鍣ㄧ粍鍖归厤鑷冲皯涓€涓浉瀵逛簬鍏冪礌鐨?scope鐨勫厓绱犮€傚叾瀹炵湅涓€涓緥瀛愶細

div--p

div--p.has

div--p

div:has(.g-test-has){border:1pxsolid#000;}鎴戜滑閫氳繃div:has(.g-test-has)閫夋嫨鍣紝鎰忔€濇槸閫夋嫨div涓媍lass涓?g-test-has鐨刣iv鍏冪礌銆傛敞鎰忚繖閲岄€夋嫨鐨勪笉鏄?has()鍖呰9鐨勯€夋嫨鍣ㄩ€夋嫨鐨勫厓绱狅紝鑰屾槸浣跨敤:has()浼被鐨勫涓诲厓绱犮€傛晥鏋滃涓嬶細鍙互鐪嬪埌鍥犱负绗簩涓猟iv涓嬮潰鏈塩lass涓?g-test-has鐨勫厓绱狅紝鎵€浠ョ粰绗簩涓猟iv娣诲姞浜嗚竟妗嗐€?has()parentselector--閫夋嫨宓屽缁撴瀯鐨勭埗鍏冪礌涓嬮潰閫氳繃鍑犱釜DEMO鏉ュ姞娣变竴涓嬪嵃璞″惂銆?has()涔熷彲浠ュ啓鎴愭洿澶嶆潅鐨勬柟寮忋€?div>div璺ㄥ害
  • divullih2璺ㄥ害

divh2span

div:has(>h2>span){margin-left:24px;border:1pxsolid#000;}杩欓噷闇€瑕佸噯纭€夋嫨div涓嬬殑鐩存帴瀛愬厓绱犱负h2锛屼笖h2涓嬬殑鐩存帴瀛愬厓绱犳湁span鐨刣iv鍏冪礌銆傝娉ㄦ剰锛岄€夋嫨鐨勬渶椤跺眰鍏冪礌鍦ㄧ埗鍏冪礌div涓婁娇鐢?has()銆傜粨鏋滃涓嬶細杩欓噷鏄祵濂楃粨鏋勶紝鍑嗙‘鏌ユ壘鍒板搴旂殑鐖跺厓绱犮€?has()parentselector--鍚岀骇缁撴瀯鐨勫厔寮熷厓绱犵殑閫夊彇杩樻湁涓€绉嶆儏鍐碉紝涔嬪墠涔熸槸姣旇緝闅惧鐞嗙殑锛屽氨鏄悓绾х粨鏋勭殑鍏勫紵鍏冪礌鐨勯€夊彇銆傜湅杩欎釜DEMO锛?divclass="has-test">div+p

p

div+h1

h1

div+h2

h2

div+ul
    ul
鎴戜滑鎯宠鍦ㄥ厔寮熷眰娆$粨鏋勪腑鎵惧埌

鍏冪礌涔嬪悗鐨?has-test鍏冪礌銆傚彲浠ヨ繖鏍峰啓锛?has-test:has(+h2){margin-left:24px;border:1pxsolid#000;}鏁堟灉濡備笅锛氳繖閲屾槸鍏勫紵缁撴瀯锛屽噯纭煡鎵惧搴旂殑pre-brother鍏冪礌銆傝繖鏍凤紝CSS涓竴鐩存病鏈夊疄鐜扮殑鐖堕€夋嫨鍣ㄤ篃鍙互閫氳繃:has()寮€濮嬪疄鐜般€傝繖涓€夋嫨鍣ㄥ彲浠ュぇ澶ф彁鍗囧紑鍙戜綋楠岋紝瑙e喅涔嬪墠闇€瑕佹洿澶欽avaScript浠g爜鎵嶈兘瀹屾垚鐨勪簨鎯呫€備互涓奃EMO鐨勬€荤粨锛屽彲浠ョ偣杩欓噷CodePenDemo--:hasDemo:has()Compatibility锛屽彲鎯滅粰浜嗕竴鐐规椂闂达紝:has()鏄湪鏈€杩戠殑SelectorsLevel4瑙勮寖涓‘瀹氱殑锛岀洰鍓嶇殑鍏煎鎬ц繕鏄瘮杈冩儴娣$殑銆傛埅鑷?022-05-04锛孲afari鍜屾渶鏂扮増Chrome锛圴101锛屽彲閫氳繃寮€鍚疎xperimentalWebPlatform鍔熻兘浣撻獙锛夐渶瑕佸湪Chrome涓嬪紑鍚鍔熻兘銆?.鍦ㄦ祻瑙堝櫒URL妗嗕腑杈撳叆chrome://flags锛?.寮€鍚?enable-experimental-web-platform-features鑰愬績绛夊緟锛岀粰瀹冧竴鐐规椂闂达紝杩欎箞濂界殑閫夋嫨鍣ㄥ緢蹇氨鑳藉ぇ瑙勬ā搴旂敤銆傛渶鍚庯紝鏈枃鍒版缁撴潫锛屽笇鏈涘浣犳湁鎵€甯姪:)鎯宠鑾峰彇鏈€鏈夎叮鐨凜SS璧勮锛屽崈涓囦笉瑕侀敊杩囨垜鐨勫叕浼楀彿鈥斺€攊CSS鍓嶇濂囬椈杞朵簨馃槃鏇村绮惧僵CSS鎶€鏈枃绔犳眹鎬诲湪鎴戠殑Github鈥斺€攊CSS锛屾寔缁洿鏂帮紝娆㈣繋鐐逛釜鏄熻闃呮敹钘忋€傛湁浠€涔堥棶棰樻垨鑰呭缓璁彲浠ュ浜ゆ祦銆傚師鍒涙枃绔犳枃绗旀湁闄愶紝鐭ヨ瘑鍖箯銆傚鏋滄枃绔犱腑鏈変换浣曚笉鍑嗙‘鐨勫湴鏂癸紝璇峰憡璇夋垜銆?/p>