목차
앞의 말
기본 사용법
상속 및 계단식
조합 및 계산
JS
은 사용할 수 없습니다. 지원
Purpose
웹 프론트엔드 CSS 튜토리얼 CSS 변수 변수 분석

CSS 변수 변수 분석

Jun 12, 2018 pm 03:25 PM

이 기사에서는 특정 참조 값이 있는 CSS 변수 분석을 주로 소개합니다. 이제 모든 사람과 공유합니다. 도움이 필요한 친구들이 참조할 수 있습니다.

앞의 말

 CSS에는 항상 변수가 없었습니다. CSS 변수의 경우 SASS 또는 LESS와 같은 사전 컴파일러만 사용할 수 있습니다. 새로운 초안이 출시되면서 CSS에서 직접 변수를 정의하고 사용하는 것은 더 이상 환상이 아닙니다. 이 글에서는 CSS 변수를 자세히 소개하겠습니다

기본 사용법

  CSS 변수는 문서 전체에서 재사용할 특정 값을 포함하는 CSS 작성자가 정의한 개체입니다. 사용자 정의 속성을 사용하여 변수 이름을 설정하고 특정 var()를 사용하여

에 액세스합니다. 호환성: 모바일 및 IE 브라우저는 호환되지 않습니다.

【변수 선언】

변수는 --로 시작해야 합니다. 예를 들어 --example-variable: 20px는 --example-varibale 변수에 20px를 할당한다는 의미입니다

변수를 선언하는 문을 모든 요소 내에 배치할 수 있습니다. 전역 변수를 설정하려면 다음과 같이 설정할 수 있습니다. : root, body 또는 html

:root{
  --bgColor:#000;
}
로그인 후 복사

  변수 선언은 일반 스타일 선언문과 동일하며 인라인 스타일도 사용할 수 있습니다

<body style="--bgColor:#000">
로그인 후 복사

  변수 선언문은 요소에 포함되어야 하며 임의로 배치할 수 없습니다

//错误
<style>
--bgColor:#000;
</style>
로그인 후 복사

【변수 사용】

 Use var( ) 함수는 변수를 사용하므로 어디에서나 사용할 수 있습니다. 예: var(--example-variable)은 --example-variable

<body style="--bgColor:#000;">
    <p style="width: 100px;height: 100px;background-color: var(--bgColor)"></p>    </body>
로그인 후 복사

에 해당하는 값을 반환합니다. var() 함수에는 변수가 값을 얻을 수 없는 경우 옵션 매개변수도 있습니다. 기본값

<body>
    <p style="width: 100px;height: 100px;background-color: var(--bgColor,pink)"></p>    </body>
로그인 후 복사

상속 및 계단식

일반 스타일 속성과 마찬가지로 변수 속성도 상속 및 계단식을 지원합니다. 아래 예에서는 body 요소의 변수 값이 녹색이고, p 요소의 변수 값이 빨간색이며, 캐스케이딩 원리에 따라 p 요소의 최종 배경색은 빨간색입니다.

<body style="--bgColor:green;">
    <p style="width: 100px;height: 100px;--bgColor: red;background-color: var(--bgColor,pink)"></p>    </body>
로그인 후 복사

조합 및 계산

[조합]

  CSS 변수를 조합하여 사용 가능

<style>.box{
    --top:20%;
    --left:30%;
    width: 100px;
    height: 100px;
    background-image: url(img/24/xiaoshu.jpg);
    background-position: var(--left)  var(--top);}</style><p class="box"></p>
로그인 후 복사

단, CSS 변수는 다음과 같은 형태로 조합할 수 없습니다. var(--color1)var(--color2)는 분리된 경우 브라우저에서 인식되지 않습니다. , 예를 들어 var(--color1) var(--color2) 는 #333으로 구문 분석되며 이는 브라우저에서도 인식할 수 없습니다.

<style>.box{
    --color1:#;
    --color2:333;
    width: 100px;
    height: 100px;
    background-color: var(--color1)var(--color2);}</style><p class="box"></p>
로그인 후 복사

【계산】

  변수는 조합 외에 일반 스타일 값과 동일합니다. , 계산에 calc를 사용할 수도 있습니다.

<style>.box{
    --borderWidth:2px;
    width: 100px;
    height: 100px;
    background-color:lightblue;
    border-left: calc(var(--borderWidth) * 2) solid black;}</style><p class="box"></p>
로그인 후 복사

JS

  CSS 변수는 JS 상호 작용과 상호 작용할 수 있습니다. getPropertyValue() 및 setProperty() 메서드만 사용할 수 있으며 스타일 속성

[스타일 속성]

<p id="box" style="--color:lightgreen;background-color: var(--color)"></p>    <script>  var oBox = document.getElementById(&#39;box&#39;);
  console.log(oBox.style[&#39;--color&#39;]);    //undefined</script>
로그인 후 복사

[getPropertyValue()]

<p id="box" style="--color:lightgreen;background-color: var(--color)"></p>    <script>  var oBox = document.getElementById(&#39;box&#39;);
  console.log(oBox.style.getPropertyValue(&#39;--color&#39;));//&#39;lightgreen&#39;</script>
로그인 후 복사

[setProperty()]

<style>#box{    
    --color:lightgreen;
    background-color: var(--color);
    width: 100px;
    height: 100px;
    display:inline-block;}</style><button id="btn" type="button">变浅蓝</button><p id="box"></p>    <script>var oBox = document.getElementById(&#39;box&#39;);var oBtn = document.getElementById(&#39;btn&#39;);
oBtn.onclick = function(){
    oBox.style.setProperty(&#39;--color&#39;,&#39;lightblue&#39;);
}</script>
로그인 후 복사

은 사용할 수 없습니다. 지원

 한 가지 특별히 주의할 점은 변수가 !important

.box{
    --color:red;
    width: 100px;
    height: 100px;
    background-color:--color !important;
}</style><p class="box"></p>
로그인 후 복사

 크롬 브라우저 스크린샷은 다음과 같습니다

Purpose

 1. 유지 관리성

색 구성표나 크기 구성표를 한 번에 유지합니다. 웹 페이지는 일부 스타일이 CSS 파일에 여러 번 나타나고 반복적으로 사용됨을 의미합니다. 계획을 수정할 때 특정 스타일을 조정하든 전체 계획을 완전히 수정하든 복잡한 문제가 되며, 이때 간단한 검색 및 교체만으로는 충분하지 않습니다. 이때 CSS 변수가 유용합니다

:root{
  --mainColor:#fc0;
}
.p1{
  color:var(--mainColor);
}
.p2{
  color:var(--mainColor);
}
로그인 후 복사

  2.

 변수의 두 번째 장점은 이름 자체에 의미 정보가 포함되어 있다는 것입니다. CSS 파일을 읽고 이해할 수 있게 됩니다. main-text-color는 문서의 #fc0보다 이해하기 쉽습니다. 특히 서로 다른 파일에 동일한 색상이 나타날 때

 3. @media 미디어 쿼리를 구현하는 것이 더 편리합니다

일반적으로 미디어 쿼리는 다음과 같습니다

<style>.box{    
    width: 100px;
    height: 100px;
    padding: 20px;
    margin: 10px;
    background-color: red}@media screen and (max-width:600px) {
    .box{
        width: 50px;
        height: 50px;
        padding: 10px;
        margin: 5px;        
    }}</style><p class="box"></p>
로그인 후 복사

 그러나 변수를 사용하면 코드를 간소화할 수 있습니다

<style>.box{    
    --base-size:10px;
    width: calc(var(--base-size) * 10);
    height: calc(var(--base-size) * 10);
    padding: calc(var(--base-size) * 2);
    margin: calc(var(--base-size) * 1);
    background-color: red;}@media screen and (max-width:600px) {
    .box{
        --base-size:5px;    
    }}</style><p class="box"></p>
로그인 후 복사

위 내용은 모두의 학습에 도움이 되기를 바랍니다.

관련 권장 사항:

CSS의 positon 속성 분석

css를 통해 자리 표시자를 설정하는 방법

위 내용은 CSS 변수 변수 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

정적 양식 공급자의 비교 정적 양식 공급자의 비교 Apr 16, 2025 am 11:20 AM

"정적 양식 공급자"라는 용어를 동전하려고합시다. 당신은 당신의 HTML을 가져옵니다

주간 플랫폼 뉴스 : HTML로드 속성, 주요 ARIA 사양 및 iframe에서 Shadow Dom으로 이동 주간 플랫폼 뉴스 : HTML로드 속성, 주요 ARIA 사양 및 iframe에서 Shadow Dom으로 이동 Apr 17, 2025 am 10:55 AM

이번 주에 플랫폼 뉴스 라운드 업 RONDUP, Chrome은로드에 대한 새로운 속성, 웹 개발자를위한 접근성 사양 및 BBC Move를 소개합니다.

Sass를 더 빨리 만들기위한 개념 증명 Sass를 더 빨리 만들기위한 개념 증명 Apr 16, 2025 am 10:38 AM

새로운 프로젝트가 시작될 때, Sass 컴파일은 눈을 깜박이게합니다. 특히 BrowserSync와 짝을 이루는 경우 기분이 좋습니다.

HTML 대화 요소와 함께 일부 실습 HTML 대화 요소와 함께 일부 실습 Apr 16, 2025 am 11:33 AM

이것은 처음으로 HTML 요소를보고 있습니다. 나는 그것을 잠시 동안 알고 있었지만 아직 스핀을 위해 그것을 가져 갔다. 그것은 꽤 시원하고 있습니다

PaperForm PaperForm Apr 16, 2025 am 11:24 AM

구매 또는 빌드는 기술 분야의 고전적인 논쟁입니다. 신용 카드 청구서에 라인 항목이 없기 때문에 물건을 구축하는 것이 저렴할 수 있지만

'Podcast 구독'링크는 어디에서 링크해야합니까? 'Podcast 구독'링크는 어디에서 링크해야합니까? Apr 16, 2025 pm 12:04 PM

한동안 iTunes는 팟 캐스팅에서 큰 개 였으므로 "Podcast 구독"을 링크 한 경우 다음과 같습니다.

빠른 Gulp 캐시 파열 빠른 Gulp 캐시 파열 Apr 18, 2025 am 11:23 AM

CSS 및 JavaScript (및 이미지 및 글꼴 등)와 같은 자산에 멀리 떨어진 캐시 헤더를 설정해야합니다. 브라우저를 알려줍니다

주간 플랫폼 뉴스 : 텍스트 간격 북마크, 최상위 차단, 새로운 앰프 로딩 표시기 주간 플랫폼 뉴스 : 텍스트 간격 북마크, 최상위 차단, 새로운 앰프 로딩 표시기 Apr 17, 2025 am 11:26 AM

이번 주에 타이포그래피를 검사하기위한 편리한 북마크 인 Roundup, JavaScript 모듈과 Facebook의 Facebook 등을 어떻게 가져 오는지 땜질하기 위해 대기하는 편리한 북마크 인 Roundup과 Facebook의

See all articles