CSS 기본 중첩 구문이 여기에 있습니다! 이용안내를 간단히 살펴보세요!
현재 CSS 네이티브 중첩 구문은 개발자 평가판 상태이며 CSS 워킹 그룹은 관련 사양을 공식화하는 중입니다. Chrome 브라우저는 버전 112에서 CSS 네이티브 중첩 기능을 공식적으로 출시할 예정입니다.
안녕하세요 여러분, 제 이름은 CUGGZ입니다.
최근 caniuse.com을 읽는 동안 Chrome 및 Edge 브라우저가 버전 109에서 CSS 기본 중첩 구문을 실험적으로 지원할 것이라는 사실을 발견했습니다!
1월 10일 Chrome 109가 출시되었고 1월 26일에는 Safari Technical Preview 162가 출시되었습니다. 두 브라우저 버전 모두 CSS 중첩에 대한 실험적 지원을 제공합니다. Chrome 관계자는 다른 스타일 규칙 내에 CSS 스타일 규칙을 중첩하는 기능을 추가하면 외부의 선택기와 내부 규칙을 결합하여 스타일 시트의 모듈성과 유지 관리성을 향상시킬 수 있다고 지적했습니다.
CSS 중첩 구문을 사용하는 방법을 살펴보겠습니다!
기본 개념
소위 중첩이란 하나의 CSS 규칙을 다른 CSS 규칙(중첩 규칙)에 넣는 것이며 하위 규칙의 선택자는 상위 규칙의 선택자를 기준으로 합니다. 이는 코드 모듈성과 유지 관리성을 용이하게 합니다. 이전에는 CSS 전처리기에서만 사용할 수 있었던 중첩 기능을 이제 기본 CSS에서도 사용할 수 있습니다.
실제로 CSS 중첩은 Sass 중첩과 유사합니다. 예를 들어 다음 CSS 스타일의 경우:
table.colortable td { text-align:center; } table.colortable td.c { text-transform:uppercase; } table.colortable td:first-child, table.colortable td:first-child+td { border:1px solid black; } table.colortable th { text-align:center; background:black; color:white; }
如果使用 CSS 嵌套时,就是这样的:
table.colortable { & td { text-align:center; &.c { text-transform:uppercase } &:first-child, &:first-child + td { border:1px solid black } } & th { text-align:center; background:black; color:white; } }
可以看到,使用嵌套不仅消除重复,相关规则的分组还提高了生成的 CSS 的可读性和可维护性。
嵌套规则
嵌套规则可以使用嵌套选择器(&) 直接引用父规则的匹配元素,或者使用相对选择器语法指定“后代”以外的关系。
.foo { color: red; &:hover { color: blue; } } /* 相当于: */ .foo { color: red; } .foo:hover { color: blue; }
.foo { color: red; + .bar { color: blue; } } /* 相当于: */ .foo { color: red; } .foo + .bar { color: blue; }
但是,以标识符(类型选择器)开始嵌套选择器是无效的:
div { color: red; input { margin: 1em; } } /* 无效,因为 input 是一个标识符 */
如果想继续这样编写,就需要稍微进行修改:
div { color: red; & input { margin: 1em; } /* 有效,不再以标识符开头 */ :is(input) { margin: 1em; } /* 有效,以冒号开头,并且等同于之前的规则 */ }
更多嵌套规则详见 CSS 嵌套规范草案:https://drafts.csswg.org/css-nesting/
嵌套选择器
在使用嵌套规则时,必须能够引用父规则匹配的元素。为此,规范中定义了一个新的选择器,即嵌套选择器,写为 & 。
当在嵌套样式规则的选择器中使用时,嵌套选择器表示与父规则匹配的元素。当在任何其他上下文中使用时,它表示与该上下文中的 :scope 相同的元素。
嵌套选择器可以通过 :is() 选择器将其替换为父样式规则的选择器。例如:
a, b { & c { color: blue; } }
这就相当于:
:is(a, b) c { color: blue; }
嵌套选择器不能表示伪元素(与 :is() 的行为相同):
.foo, .foo::before, .foo::after { color: red; &:hover { color: blue; } }
这里,& 只代表.foo匹配的元素,它等同于:
.foo, .foo::before, .foo::after { color: red; } .foo:hover { color: blue; }
嵌套选择器的特异性(权重)等于父样式规则的选择器列表中复杂选择器中最大的特异性(与 :is() 的行为相同):
#a, b { & c { color: blue; } } .foo c { color: red; }
DOM 结构如下:
<b> <c>Blue text</c> </b>
文本将是蓝色的,而不是红色的。& 的特异度是 #a([1,0,0]) 和 b([0,0,1]) 特异性中较大的一个,所以是 [1,0,0],而整个 & c 选择器具有特异性 [1,0,1],它大于 .foo c ([0,1,1]) 的特异性。
值得注意的是,这与将嵌套手动扩展为非嵌套规则时得到的结果不同,因为 color: blue 声明将由 b c 选择器 ([0,0,2]) 匹配,而不是#a c ([1,0,1])。
小结
目前,CSS 原生嵌套语法处于开发者试用状态,CSS 工作组正在制定相关规范,Chrome 浏览器预计将于 112 版本正式推出 CSS 原生嵌套功能。
由于 CSS 嵌套语法规范尚未完成,随时可能进行更改。因此,本文所展示的规则可能会有所变化。期待不久的将来 CSS 原生嵌套语法登录浏览器正式版本!
推荐学习:《CSS视频教程》
위 내용은 CSS 기본 중첩 구문이 여기에 있습니다! 이용안내를 간단히 살펴보세요!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

HTML은 웹 구조를 정의하고 CSS는 스타일과 레이아웃을 담당하며 JavaScript는 동적 상호 작용을 제공합니다. 세 사람은 웹 개발에서 의무를 수행하고 화려한 웹 사이트를 공동으로 구축합니다.

부트 스트랩 분할 라인을 만드는 두 가지 방법이 있습니다 : 태그를 사용하여 수평 분할 라인이 생성됩니다. CSS 테두리 속성을 사용하여 사용자 정의 스타일 분할 라인을 만듭니다.

WebDevelopmentReliesonHtml, CSS 및 JavaScript : 1) HtmlStructuresContent, 2) CSSSTYLESIT, 및 3) JAVASCRIPTADDSINGINTERACTIVITY, BASISOFMODERNWEBEXPERIENCES를 형성합니다.

부트 스트랩 프레임 워크를 설정하려면 다음 단계를 따라야합니다. 1. CDN을 통해 부트 스트랩 파일 참조; 2. 자신의 서버에서 파일을 다운로드하여 호스팅하십시오. 3. HTML에 부트 스트랩 파일을 포함; 4. 필요에 따라 Sass/Less를 컴파일하십시오. 5. 사용자 정의 파일을 가져옵니다 (선택 사항). 설정이 완료되면 Bootstrap의 그리드 시스템, 구성 요소 및 스타일을 사용하여 반응 형 웹 사이트 및 응용 프로그램을 만들 수 있습니다.

Bootstrap에 이미지를 삽입하는 방법에는 여러 가지가 있습니다. HTML IMG 태그를 사용하여 이미지를 직접 삽입하십시오. 부트 스트랩 이미지 구성 요소를 사용하면 반응 형 이미지와 더 많은 스타일을 제공 할 수 있습니다. 이미지 크기를 설정하고 IMG-Fluid 클래스를 사용하여 이미지를 적응할 수 있도록하십시오. IMG 통과 클래스를 사용하여 테두리를 설정하십시오. 둥근 모서리를 설정하고 IMG 라운드 클래스를 사용하십시오. 그림자를 설정하고 그림자 클래스를 사용하십시오. CSS 스타일을 사용하여 이미지를 조정하고 배치하십시오. 배경 이미지를 사용하여 배경 이미지 CSS 속성을 사용하십시오.

부트 스트랩 버튼을 사용하는 방법? 부트 스트랩 CSS를 소개하여 버튼 요소를 만들고 부트 스트랩 버튼 클래스를 추가하여 버튼 텍스트를 추가하십시오.
