>웹 프론트엔드 >CSS 튜토리얼 >2017년에 배울 가치가 있는 3가지 새로운 CSS 기능(권장)

2017년에 배울 가치가 있는 3가지 새로운 CSS 기능(권장)

怪我咯
怪我咯원래의
2017-04-06 10:50:311431검색

height: 1.76em;">많은 새로운 CSS 기능 중 올해 채택된 3가지 새로운 기능은 저를 주체할 수 없을 정도로 흥분하게 만듭니다.

1 . 기능 쿼리

얼마 전에 제가 정말 바라던 CSS 기능을 작성했는데, 기능 쿼리에 관한 것입니다. 이제는 기본적으로 이미 Internet Explorer(Opera Mini 포함)를 제외한 주요 브라우저를 지원한다고 할 수 있습니다! ). @supports 규칙을 사용하는

기능 쿼리를 사용하면 현재 사용자 에이전트가 CSS 속성 키-값 쌍을 지원하는지 확인하는 조건부 블록에 CSS를 포함할 수 있습니다. 지원되는 경우에만 적용됩니다. 다음은 브라우저가 Flexbox를 지원할 때만 표시를 적용하는 간단한 예입니다. flex -

@supports ( display: flex ) {
  .foo { display: flex; }
}

또한 이 연산자와 함께 like 및 not을 사용하세요. , 예를 들어 브라우저가 이전 Flexbox 구문(

@supports ( display: flexbox ) 
          and 
          ( not ( display: flex ) ) {
  .foo { display: flexbox; }
}

지원 상태

2017년에 배울 가치가 있는 3가지 새로운 CSS 기능(권장)2.

테이블

레이아웃CSS 테이블 레이아웃 모듈에 의해 정의된 시스템은 flexbox 레이아웃 모듈과 유사하지만 더 명시적으로 설계되었습니다.

페이지 레이아웃

그리고 그 사이에는 다양한 기능이 있습니다 명시적인 항목 위치 지정

그리드는 테이블 컨테이너(디스플레이: 그리드 생성을 통해)와 테이블 항목(하위 구성 요소)으로 표현됩니다. ) CSS에서는 태그(HTML 태그 참조)에 관계없이 테이블 항목의 위치와 순서를 명확하게 구성할 수 있습니다. 예를 들어, 이 기사에서는 거룩한 레이아웃을 만드는 방법을 보여줍니다. 이 모듈을 통해 유명한 "성배 레이아웃"이 탄생했습니다.

단 31개 행 -

.hgheader { grid-area: header; }
.hgfooter { grid-area: footer; }
.hgmain { grid-area: main; }
.hgleft { grid-area: navigation; }
.hgright { grid-area: ads; }

.hg {
    display: grid;
    grid-template-areas: "header header header"
                         "navigation main ads"
                         "footer footer footer";
    grid-template-columns: 150px 1fr 150px;
    grid-template-rows: 100px 
                        1fr
                        30px;
    min-height: 100vh;
}

@media screen and (max-width: 600px) {
    .hg {
        grid-template-areas: "header"
                             "navigation"
                             "main"
                             "ads"
                             "footer";
        grid-template-columns: 100%;
        grid-template-rows: 100px 
                            50px 
                            1fr
                            50px 
                            30px;
    }
}

유연한 길이

2017년에 배울 가치가 있는 3가지 새로운 CSS 기능(권장)CSS 그리드 모듈은 테이블 컨테이너의 남은 공간을 동일하게 나누는 것을 나타내는 새로운 길이 단위 fr. 🎜>테이블 컨테이너의 사용 가능한 공간에 따라 테이블 항목에 높이와 너비를 할당할 수 있습니다. 성배 레이아웃에서는 메인 파티션이 두 개의 사이드바를 제외한 모든 공간을 차지하도록 하고 싶습니다. 이를 위한 간단한 코드 -

.hg {
    grid-template-columns: 150px 1fr 150px;
}

Gap

그리드 행을 사용할 수 있습니다. -gap, Grid-column-gap 및 Grid-gap 속성을 사용하여 간격을 명시적으로 정의합니다. 이러한 속성의 값은 콘텐츠 영역 크기의 백분율인

데이터 유형

입니다.

예를 들어 %5 간격이 필요한 경우 이렇게 작성하면 됩니다. -

.hg {
    display: grid;
    grid-column-gap: 5%;
}

지원

CSS 그리드 모듈은 올해 3월 브라우저에서 처음 지원되었습니다.

3. 네이티브

변수

마지막으로 이야기할 것은 네이티브 CSS 변수입니다. 이 모듈에서는 작성자

가 CSS 속성처럼 할당할 수 있는 변수 2017년에 배울 가치가 있는 3가지 새로운 CSS 기능(권장)를 정의하는 방법을 소개합니다.

예를 들어 테마 색상이 스타일 시트의 여러 위치에서 사용되는 경우 실제 값을 직접 여러 번 작성하는 대신 이를 추상화하여 변수에 저장한 다음 변수를 참조할 수 있습니다.
:root {
  --theme-colour: cornflowerblue;
}

h1 { color: var(--theme-colour); }  
a { color: var(--theme-colour); }  
strong { color: var(--theme-colour); }
현재 SASS와 같은 CSS 전처리기에서 이러한 작업을 수행할 수 있지만 CSS 변수는 브라우저에서 활성화됩니다. 즉, 해당 값이 실시간으로

업데이트

될 수 있습니다. 예를 들어, 위 예에서 --theme-color 속성의 값을 변경하려면 -

const rootEl = document.documentElement;  
rootEl.style.setProperty('--theme-colour', 'plum');
Support

만 수행하면 됩니다. 지원은 무엇입니까?

보시다시피 현재 모든 브라우저에서 지원되는 기능은 없는데, 안심하고 프로덕션에서 사용하려면 어떻게 해야 할까요? 대답은: 점진적인 향상입니다! 작년에 나는 Fronteers Conference에서 CSS와 관련된 점진적인 향상에 관해 연설했습니다. 이제 여기에 올려요 -

2017년에 배울 가치가 있는 3가지 새로운 CSS 기능(권장)

위 내용은 2017년에 배울 가치가 있는 3가지 새로운 CSS 기능(권장)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.