成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

初次接觸CSS變量

番茄西紅柿 / 1428人閱讀

摘要:列如代碼代碼就業(yè)協(xié)議書(shū)就業(yè)協(xié)議書(shū),全稱(chēng)是全國(guó)普通高等學(xué)校畢業(yè)生就業(yè)協(xié)議書(shū),是由教育部高校學(xué)生司統(tǒng)一制訂的。根據(jù)國(guó)家規(guī)定,在達(dá)成就業(yè)意向后,畢業(yè)生用人單位學(xué)校三方必須簽訂全國(guó)普通高等學(xué)校畢業(yè)生就業(yè)協(xié)議書(shū)。

本文的目的主要是展示CSS變量是如何工作的。隨著Web應(yīng)用程序變得越來(lái)越大,CSS變得越來(lái)越大,越來(lái)越多,而且很多時(shí)候都很亂,在良好的上下文中使用CSS變量,為您提供重用和輕松更改重復(fù)出現(xiàn)的CSS屬性的機(jī)制。

在“純粹的”CSS支持變量之前,我們有像LessSass這樣的預(yù)處理器。但是它們需要在使用前進(jìn)行編譯,因此(有時(shí))會(huì)增加額外的復(fù)雜性。

 

如何定義和使用CSS變量

從我們最熟悉的語(yǔ)言JavaScript開(kāi)始:在JavaScript中定義變量使用vars。

要聲明一個(gè)簡(jiǎn)單的JavaScript var,如下內(nèi)容:

var mainColor = red;

 

要聲明一個(gè)CSS變量,您必須在該var的名稱(chēng)前添加一個(gè)雙短劃線。例如:

body{
    --color:red;
}

 

現(xiàn)在,為了使用CSS變量的值,我們可以使用var(...)函數(shù)。如下:

.demo{
    background:var(--color);
}

 

管理CSS變量的最簡(jiǎn)單方法是將它們聲明為:root偽類(lèi)。鑒于CSS變量遵循規(guī)則,就像任何其他CSS定義一樣,將它們放在:root中將確保所有選擇器都可以訪問(wèn)這些變量。

:root{
    --color:red;
}
            
.demo{
    background:var(--color);
}
            
p{
    color:var(--color);
}

瀏覽器支持CSS變量?

瀏覽器對(duì)CSS變量的支持還算不錯(cuò)的。只是IE瀏覽器不支持。想查看瀏覽器兼容性的可以點(diǎn)擊這里,那么您將看到所有主流瀏覽器都支持開(kāi)箱即用的CSS變量。無(wú)論是手機(jī)還是臺(tái)式機(jī)。

 

CSS變量的實(shí)質(zhì)應(yīng)用

示例1 - 管理顏色

到目前為止,使用CSS變量的最佳候選者之一是管理網(wǎng)頁(yè)的顏色。我們可以將它們放在變量中,而不是一遍又一遍地復(fù)制和粘貼相同的顏色。如果有人要求我們更新特定的綠色陰影或使所有按鈕變?yōu)榧t色而不是藍(lán)色,那么只需更改該CSS變量的值,就是這樣。您不必搜索和替換該顏色的所有實(shí)例。

列如:

CSS代碼

/*css_vars.css*/
:root {
  --primary-color: #ed6564;
  --accent-color: #388287;
}

html {
  background-color: var(--primary-color);
}

h3 {
  border-bottom: 2px solid var(--primary-color);
}

button {
  color: var(--accent-color);
  border: 1px solid var(--accent-color);
}

p {
  color: var(--accent-color);
}


/*base.css*/
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  padding: 30px;
  font: normal 13px/1.5 sans-serif;
  color: #546567;
  background-color: var(--primary-color);
}

.container {
  background: #fff;
  padding: 20px;
}

h3 {
  padding-bottom: 10px;
  margin-bottom: 15px;
}

p {
  background-color: #fff;
  margin: 15px 0;
}

button {
  margin:0 5px;
  font-size: 13px;
  padding: 8px 12px;
  background-color: #fff;
  border-radius: 3px;
  box-shadow: none;
  text-transform: uppercase;
  font-weight: bold;
  cursor: pointer;
  opacity: 0.8;
  outline: 0;
}

button:hover {
  opacity: 1;
}

.center {
  text-align: center;
}

 

HTML代碼

<div class="container">
  <h3>就業(yè)協(xié)議書(shū)h3>
  <p>就業(yè)協(xié)議書(shū),全稱(chēng)是《全國(guó)普通高等學(xué)校畢業(yè)生就業(yè)協(xié)議書(shū)》,是由教育部高校學(xué)生司統(tǒng)一制訂的。根據(jù)國(guó)家規(guī)定,在達(dá)成就業(yè)意向后,畢業(yè)生、用人單位、學(xué)校三方必須簽訂《全國(guó)普通高等學(xué)校畢業(yè)生就業(yè)協(xié)議書(shū)》。就業(yè)協(xié)議書(shū)是具有一定的廣泛性和權(quán)威性,是學(xué)校制訂就業(yè)方案派遣畢業(yè)生、用人單位申請(qǐng)用人指標(biāo)的主要依據(jù),對(duì)簽約的三方都有約束力。p>
  <div class="center">
    <button>查看詳情button><button>取消button>
  div>
div>

點(diǎn)擊查看運(yùn)行結(jié)果。

 

示例2 - 刪除重復(fù)的代碼

通常,您需要構(gòu)建一些不同的組件變體。相同的基本樣式,略有不同。讓我們使用一些顏色不同的按鈕。典型的解決方案是創(chuàng)建一個(gè)基類(lèi),比如.btn并添加變體類(lèi)。

.btn {
  border: 2px solid black;}

.btn:hover {
  background: black;}

.btn.red {
  border-color: red
}
.btn.red:hover {
  background: red
}

 

現(xiàn)在使用它們像這樣:

<button class="btn">Hellobutton>
<button class="btn red">Hellobutton>

但是,這會(huì)添加一些代碼重復(fù)。在.red變體上,我們必須將border-color和background設(shè)置為紅色。

 

這中情況可以使用CSS變量輕松修復(fù)。如下:

CSS代碼:

.btn{
  border-radius:4px;
  text-align:center;
  padding:.5em;
  margin-bottom:0.5em;
  background:#fff;
  border:1px solid var(--color, black);
}

.btn:hover{
  color:#fff;
  cursor:pointer;
  background:var(--color, black);
}

.btn.red{
  --color:red;
}

.btn.green{
  --color:green;
}

.btn.blue{
  --color:blue;
}

 

HTML代碼:

<div class="btn">HMOEdiv>
<div class="btn red">HMOEdiv>
<div class="btn green">HMOEdiv>
<div class="btn blue">HMOEdiv>

 

示例3 - 使一些屬性可讀

如果我們想要?jiǎng)?chuàng)建更復(fù)雜的屬性值的快捷方式,CSS vars非常適合使用,因此我們不必記住它。CSS屬性,如box-shadow,transform和font或其他帶有多個(gè)參數(shù)的CSS規(guī)則就是完美的例子。我們可以將屬性放在變量中,以便我們可以通過(guò)更易讀的格式重用它。

例如:

:root {
  --tiny-shadow: 4px 4px 2px 0 rgba(0, 0, 0, 0.8);
  --animate-right: translateX(20px);
}

li {
  box-shadow: var(--tiny-shadow);
}

li:hover {
  transform: var(--animate-right);
}

 

例4 - 級(jí)聯(lián)變量

標(biāo)準(zhǔn)級(jí)聯(lián)規(guī)則也適用于CSS變量。因此,如果多次聲明自定義屬性,則css文件中最低的定義將覆蓋其上方的定義。下面的示例演示了動(dòng)態(tài)操作用戶操作的屬性是多么容易,同時(shí)仍然保持代碼清晰簡(jiǎn)潔。

CSS_var.css文件:

.orange-container {
  --main-text: 18px;
}

.orange-container:hover { --main-text: 22px; }

.red-container:hover { --main-text: 26px; }

.title { font-size: var(--title-text); }

.content { font-size: var(--main-text); } .container:hover { --main-text: 18px; }

 

base.css文件:

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  background: #eee;
  padding: 30px;
  font: 500 14px sans-serif;
  color: #333;
  line-height: 1.5;
}

.orange-container {
  background: orange;
}

.red-container {
  background: red;
}

.red-container,
.orange-container {
  padding-top: 10px;
  padding-left: 50px;
}

.container {
  background: blue;
  padding: 20px;
  color: white;
}

p {
  transition: 0.4s;
}

.title {
  font-weight: bold;
}

 

index.html文件:

<html>

<head>
<link rel="stylesheet" type="text/css" href="base.css">
<link rel="stylesheet" type="text/css" href="css_vars.css">
head>

<body>
<div class="orange-container">
    Hover orange to make blue bigger.
    <div class="red-container">
         Hover red to make blue even bigger.
        <div class="container">
            <p class="content">Hover on the different color areas to change the size of this text and the title.p>
        div>
    div>
div>
body>

html>

點(diǎn)擊查看運(yùn)行結(jié)果。

 

示例5 - 具有CSS變量的主題切換器

CSS變量的一個(gè)好處是它的反應(yīng)性。一旦我們更新它,任何具有CSS變量值的屬性也會(huì)更新。因此,只需幾行Javascript和CSS變量的智能使用,我們就可以制作一個(gè)主題切換器機(jī)制。

例如:

DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>具有CSS變量的主題切換器title>    
        <style>
            
            body {
              background-color: var(--bg, #b3e5fc);
              color: var(--bg-text, #37474f);
              font-family: sans-serif;
              line-height: 1.3;
            }
            
            .toolbar {
              text-align: center;
            }
            
        style>
    head>
    <body>
        
        <div class="toolbar">
            <button value="dark">darkbutton>
            <button value="calm">calmbutton>
            <button value="light">lightbutton>
        div>
    
        <h2>Stackoverflow Questionh2>
        <p>I would like to use an external javascript file in another javascript file. For example, I could store all my global variables
        in a globals.js file and then call then from the website logic logic.js. Then in the index.html, i would insert the tag.
        How do I use the globals.js inside the logic.js?
        p>
        <script>
            var root = document.documentElement;
            var themeBtns = document.querySelectorAll(".toolbar > button");
            
            themeBtns.forEach(function (btn){
              btn.addEventListener("click", handleThemeUpdate);
            });
            
            function handleThemeUpdate(e) {
              switch (e.target.value) {
                case "dark":
                  root.style.setProperty("--bg", "black");
                  root.style.setProperty("--bg-text", "white");
                  break;
                case "calm":
                  root.style.setProperty("--bg", "#B3E5FC");
                  root.style.setProperty("--bg-text", "#37474F");
                  break;
                case "light":
                  root.style.setProperty("--bg", "white");
                  root.style.setProperty("--bg-text", "black");
                  break;
              }
            }
        script>

    body>
html>

點(diǎn)擊查看運(yùn)行結(jié)果

 

 

CSS變量的使用提示

像CSS中幾乎所有的東西一樣,變量也非常簡(jiǎn)單易用。以下是一些未包含在示例中的提示,但在某些情況下仍然非常有用:

1)css變量區(qū)分大小寫(xiě)。下面的示例是兩個(gè)不同的變量:

:root {
   --color: blue;
   --COLOR: red;
}

2)當(dāng)您使用var()函數(shù)時(shí),您可以使用第二個(gè)參數(shù)。如果找不到自定義屬性,將使用第二個(gè)參數(shù)為默認(rèn)值:

width: var(--custom-width, 50%);

3)可以直接將CSS變量用于HTML:


<html style="--size: 600px">


body {
  max-width: var(--size)
}

4) 可以在其他CSS var中使用CSS變量:

--base-red-color: #f00;
--background-gradient: linear-gradient(to top, var(--base-red-color), #222);

5) 可以使用媒體查詢使CSS變量成為條件。例如,以下代碼根據(jù)屏幕大小更改填充的值:

:root {
    --padding: 15px 
}

@media screen and (min-width: 750px) {
    --padding: 30px
}

6) 不要害怕在 clac() 函數(shù)中使用CSS變量。

--text-input-width: 5000px;
max-width: calc(var(--text-input-width) / 2);

當(dāng)然,CSS變量不是靈丹妙藥。不會(huì)解決你在CSS領(lǐng)域遇到的每一個(gè)問(wèn)題。但是,使用它使您的代碼更具可讀性和可維護(hù)性。此外,它極大地改善了大型文檔的易變性。只需將所有常量設(shè)置在一個(gè)多帶帶的文件中,當(dāng)您只想對(duì)變量進(jìn)行更改時(shí),就不必跳過(guò)數(shù)千行代碼。

 

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/2046.html

相關(guān)文章

  • 初次接觸java

    摘要:運(yùn)行環(huán)境解釋器開(kāi)發(fā)工具包編譯器類(lèi)庫(kù)工具安裝執(zhí)行安裝包環(huán)境變量配置安裝目錄,讓第三方依賴(lài)于的軟件使用的工具命令所在目錄,已有值后拼接字節(jié)碼文件所在目錄,一般配置當(dāng)前目錄第一個(gè)程序格式類(lèi)名如編譯源文件名運(yùn)行類(lèi)名中的代碼都是包含在類(lèi)之中。 計(jì)算機(jī)組成: 輸出設(shè)備 輸入設(shè)備 運(yùn)算器、控制器(cpu) 存儲(chǔ)器(硬盤(pán)、內(nèi)存) --馮洛伊曼體系結(jié)構(gòu) 計(jì)算機(jī)中數(shù)據(jù)處理方式:二進(jìn)制、只有加法 原碼:二...

    maxmin 評(píng)論0 收藏0
  • 初次接觸ReactNative,搭建環(huán)境、調(diào)試時(shí)遇到的報(bào)錯(cuò)們及解決方法

    摘要:初次搭建總會(huì)碰上各種報(bào)錯(cuò)以及紅黃屏報(bào)錯(cuò)如果尚未搭建環(huán)境,請(qǐng)轉(zhuǎn)至官網(wǎng)搭建紅屏是程序無(wú)法正常運(yùn)行,黃屏是程序可以運(yùn)行但是可能存在一些潛在問(wèn)題首次使用命令行工具來(lái)創(chuàng)建一個(gè)名為的新項(xiàng)目后運(yùn)行后會(huì)報(bào)錯(cuò),如圖解決方法到你的已有項(xiàng)目中復(fù)制一份文件到 初次搭建ReactNative總會(huì)碰上各種報(bào)錯(cuò)以及紅黃屏報(bào)錯(cuò)如果尚未搭建環(huán)境,請(qǐng)轉(zhuǎn)至官網(wǎng)搭建https://reactnative.cn/docs/g....

    elliott_hu 評(píng)論0 收藏0
  • ApacheCN 人工智能知識(shí)樹(shù) v1.0

    摘要:貢獻(xiàn)者飛龍版本最近總是有人問(wèn)我,把這些資料看完一遍要用多長(zhǎng)時(shí)間,如果你一本書(shū)一本書(shū)看的話,的確要用很長(zhǎng)時(shí)間。為了方便大家,我就把每本書(shū)的章節(jié)拆開(kāi),再按照知識(shí)點(diǎn)合并,手動(dòng)整理了這個(gè)知識(shí)樹(shù)。 Special Sponsors showImg(https://segmentfault.com/img/remote/1460000018907426?w=1760&h=200); 貢獻(xiàn)者:飛龍版...

    劉厚水 評(píng)論0 收藏0
  • styled-components 中文文檔翻譯及不完全指北

    摘要:前言官方文檔地址中文文檔地址是一個(gè)的第三方庫(kù),是的優(yōu)秀實(shí)踐。初次了解是在讀林昊翻譯的設(shè)計(jì)模式與最佳實(shí)踐一書(shū)時(shí)。能力所限,已翻譯部分可能仍有字詞錯(cuò)誤或語(yǔ)句不通順的地方,歡迎有能力的同學(xué)幫助糾正。就是其中的佼佼者。 前言 官方文檔地址: https://www.styled-components.com/ 中文文檔地址:https://github.com/hengg/styled-com...

    Vicky 評(píng)論0 收藏0
  • styled-components 中文文檔翻譯及不完全指北

    摘要:前言官方文檔地址中文文檔地址是一個(gè)的第三方庫(kù),是的優(yōu)秀實(shí)踐。初次了解是在讀林昊翻譯的設(shè)計(jì)模式與最佳實(shí)踐一書(shū)時(shí)。能力所限,已翻譯部分可能仍有字詞錯(cuò)誤或語(yǔ)句不通順的地方,歡迎有能力的同學(xué)幫助糾正。就是其中的佼佼者。 前言 官方文檔地址: https://www.styled-components.com/ 中文文檔地址:https://github.com/hengg/styled-com...

    OnlyLing 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<