国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專(zhuān)欄INFORMATION COLUMN

CSS 模塊

Enlightenment / 2050人閱讀

摘要:通過(guò)使用或者從中導(dǎo)入文件使得模塊被編譯成為可能。模塊一次只運(yùn)行一個(gè)文件,這樣可以避免全局上下文的污染。下面讓我們用重構(gòu)這些這些代碼這是一個(gè)進(jìn)化版,但是我們僅僅只達(dá)到了一部分目標(biāo)。

原文:http://glenmaddern.com/articl...
譯者:@公子

如果你想知道 CSS 最近發(fā)展的轉(zhuǎn)折點(diǎn),你應(yīng)該選擇去觀看 Christopher Chedeau 在2014年11月的 NationJS 大會(huì)上做的名稱(chēng)為 CSS in JS 的分享。不得不說(shuō)這是一個(gè)技術(shù)分水嶺的時(shí)刻,一群不同的思維在自己的方向上就像粒子進(jìn)入了高能漩渦中一樣飛速發(fā)展。其中,在 React 或者是 React 相關(guān)的項(xiàng)目中編寫(xiě) CSS 樣式,React Style, jxstyle 和 Radium 這三個(gè)算是最新的,最好的以及最具有可行性的方法。如果說(shuō)“發(fā)明”是探索 最接近的可能 的一個(gè)實(shí)例(譯者注:最接近的可能是 Steven Johnson 于 2010 年提出來(lái)的一個(gè)概念),那么 Christopher 則是讓許許多多的可能變得更加接近(譯者注:上面三個(gè)工具中的兩個(gè)靈感都是來(lái)自他的分享)。

上圖列出的這些都是在許多大型 CSS 代碼庫(kù)中存在的問(wèn)題。Christopher 指出,只要將你的樣式通過(guò)用 JS 去管理,這些問(wèn)題都能很好的解決。不得不說(shuō)這的確是有道理的,但是這種方法有它的復(fù)雜性并會(huì)帶來(lái)其他的相關(guān)問(wèn)題。其實(shí)只要看看瀏覽器是如何處理 :hover 偽類(lèi)狀態(tài)的,我們就會(huì)發(fā)現(xiàn)有些東西在 CSS 中其實(shí)很早就解決了。

CSS 模塊小組 覺(jué)得我們可以更加合理的解決問(wèn)題:我們可以繼續(xù)保持 CSS 現(xiàn)在的樣子,并在 styles-in-JS 社區(qū)的基礎(chǔ)上建立更合理的改進(jìn)。雖然我們已經(jīng)找到了解決辦法同時(shí)又捍衛(wèi)了 CSS 原始的美,但我們?nèi)匀磺纺切┌盐覀兺葡蜻@個(gè)結(jié)果的那些人一聲感謝。謝謝你們,朋友們!

下面讓我來(lái)向大家解說(shuō)一下什么是 CSS 模塊并且為什么它才是未來(lái)吧。

第一步:像局部一樣無(wú)需考慮全局沖突

在 CSS 模塊中,每一個(gè)文件被編譯成獨(dú)立的文件。這樣我們就只需要使用通用簡(jiǎn)單的類(lèi)選擇器名字就好了。我們不需要擔(dān)心它會(huì)污染全局的變量。下面我就我們編寫(xiě)一個(gè)擁有四個(gè)狀態(tài)的按鈕來(lái)說(shuō)明這個(gè)功能。

https://jsfiddle.net/pqnot81c...

CSS 模塊之前我們是怎么做的

我們也許會(huì)使用 Suit/BEM 命名規(guī)范去進(jìn)行樣式命名,這樣我們的 HTML 和 CSS 代碼看起來(lái)就像如下所示:

/* components/submit-button.css */
.Button { /* all styles for Normal */ }
.Button--disabled { /* overrides for Disabled */ }
.Button--error { /* overrides for Error */ }
.Button--in-progress { /* overrides for In Progress */

這樣寫(xiě)看起來(lái)還挺棒的。使用 BEM 命令方式使我們有了 4 個(gè)樣式變量這樣我們不必使用嵌套選擇器。使用Button這種首字母大寫(xiě)的方法可以很好的避免與之前的代碼或者是其他的依賴(lài)代碼進(jìn)行沖突。另外我們使用了--語(yǔ)法這樣能很清楚的顯示出我們的依賴(lài) Class。

總的來(lái)說(shuō),這樣做可以讓我們的代碼更易于維護(hù),但是它需要我們?cè)诿?guī)范的學(xué)習(xí)上付出很多努力。不過(guò)這已經(jīng)是目前 CSS 能給出的最好的解決辦法了。

CSS 模塊出來(lái)之后我們是怎么做的

CSS 模塊意味著你從此再也不必為你的名字太大眾而擔(dān)心,只要使用你覺(jué)得有最有意義的名字就好了:

/* components/submit-button.css */
.normal { /* all styles for Normal */ }
.disabled { /* all styles for Disabled */ }
.error { /* all styles for Error */ }
.inProgress { /* all styles for In Progress */

請(qǐng)注意我們這里并沒(méi)有在任何地方使用 button 這個(gè)詞。不過(guò)反過(guò)來(lái)想,為什么我們一定要使用它呢?這個(gè)文件已經(jīng)被命名成了 submit-button.css 了呀!既然在其它的語(yǔ)言中你不需要為你的局部變量增加前綴,沒(méi)道理 CSS 需要加上這個(gè)蹩腳的功能。

通過(guò)使用 require 或者 import 從 JS 中導(dǎo)入文件使得 CSS 模塊被編譯成為可能。

/* components/submit-button.js */
import styles from "./submit-button.css";

buttonElem.outerHTML = ``

你不必?fù)?dān)心大眾名字會(huì)倒置命名沖突,編譯后實(shí)際上類(lèi)名是會(huì)自動(dòng)生成并保證是唯一的。CSS 模塊為你做好一切,最終編譯成一個(gè) CSS 與 JS 交互的 ICSS 后綴文件(閱讀這里了解更多)。因此,你的程序最終看起來(lái)可能會(huì)是這個(gè)樣子的:

如果你的類(lèi)名變的和上面的例子差不多的話(huà),那么恭喜你你成功了!

命名約定

現(xiàn)在回過(guò)頭來(lái)仔細(xì)看看我們的示例代碼:

/* components/submit-button.css */
.normal { /* all styles for Normal */ }
.disabled { /* all styles for Disabled */ }
.error { /* all styles for Error */ }
.inProgress { /* all styles for In Progress */

請(qǐng)注意所有的類(lèi)都是相互獨(dú)立的,這里并不存在一個(gè)“ 基類(lèi) ”然后其它的類(lèi)集成并“ 覆蓋 ”它的屬性這種情況。在 CSS 模塊中 每一個(gè)類(lèi)都必須包含這個(gè)元素需要的所有樣式 (稍后會(huì)有詳細(xì)說(shuō)明)。這使得你在 JS 中使用樣式的時(shí)候有很大的不同:

/* Don"t do this */
`class=${[styles.normal, styles["in-progress"]].join(" ")}`

/* Using a single name makes a big difference */
`class=${styles["in-progress"]}`

/* camelCase makes it even better */
`class=${styles.inProgress}`

當(dāng)然,如果你的工資是按照字符串長(zhǎng)度來(lái)計(jì)算的話(huà),你愛(ài)怎么做就怎么做吧!

React 示例

CSS 模塊并不是 React 特有的功能,但是不得不說(shuō)在 React 中使用 CSS 模塊會(huì)更爽。基于這個(gè)理由,我覺(jué)得我有必要展示下面這個(gè)如飄柔般絲滑的示例:

/* components/submit-button.jsx */
import { Component } from "react";
import styles from "./submit-button.css";

export default class SubmitButton extends Component {
  render() {
    let className, text = "Submit"
    if (this.props.store.submissionInProgress) {
      className = styles.inProgress
      text = "Processing..."
    } else if (this.props.store.errorOccurred) {
      className = styles.error
    } else if (!this.props.form.valid) {
      className = styles.disabled
    } else {
      className = styles.normal
    }
    return 
  }
}

你完全不需要擔(dān)心你的類(lèi)命名會(huì)和全局的樣式表命名沖突,這樣能讓你的注意力更集中在組件上,而不是樣式。我敢保證,使用過(guò)一次之后,你會(huì)再也不想回到原來(lái)的模式中去。

然而這僅僅是一切的開(kāi)始。CSS 模塊化是你的基本,但也是時(shí)候來(lái)思考一下如何把你的樣式們都集中到一塊了。

第二步:組件就是一切

上文中我提到了每一個(gè)類(lèi)必須包含按鈕不同狀態(tài)下的所有的樣式,與 BEM 命名方式上相比,代碼上可能區(qū)別如下:

/* BEM Style */
innerHTML = `

那么問(wèn)題來(lái)了,你怎么在所有的狀態(tài)樣式中共享你的樣式呢?這個(gè)答案就是 CSS 模塊的強(qiáng)力武器 - 組件

.common {
  /* all the common styles you want */
}
.normal {
  composes: common;
  /* anything that only applies to Normal */
}
.disabled {
  composes: common;
  /* anything that only applies to Disabled */
}
.error {
  composes: common;
  /* anything that only applies to Error */
}
.inProgress {
  composes: common;
  /* anything that only applies to In Progress */
}

composes這個(gè)關(guān)鍵詞將會(huì)使.normal類(lèi)將.common內(nèi)的所有樣式包含進(jìn)來(lái),這個(gè)有點(diǎn)像 Sass 的 @extends 語(yǔ)法。但是 Sass 依賴(lài)重寫(xiě)你的 CSS 文件達(dá)到效果,而 CSS 模塊最后會(huì)通過(guò) JS 編譯導(dǎo)出,不需要修改文件(譯者注:下面會(huì)有例子詳細(xì)說(shuō)明)。

Sass

按照 BEM 的命名規(guī)范,我用 Sass 的 @extends 寫(xiě)的話(huà)可能會(huì)像如下的代碼:

.Button--common { /* font-sizes, padding, border-radius */ }
.Button--normal {
  @extends .Button--common;
  /* blue color, light blue background */
}
.Button--error {
  @extends .Button--common;
  /* red color, light red background */
}

編譯后的 CSS 文件如下:

.Button--common, .Button--normal, .Button--error {
  /* font-sizes, padding, border-radius */
}
.Button--normal {
  /* blue color, light blue background */
}
.Button--error {
  /* red color, light red background */
}

你可以只需要個(gè)類(lèi)來(lái)標(biāo)記你的元素

這就是 composes 語(yǔ)法的厲害之處,你可以在不重寫(xiě)你的 CSS 的情況下對(duì)你的元素混合使用不同類(lèi)的樣式。

第三步:文件間共享

Sass 或者 LESS 中,你可以在每個(gè)文件中使用 @import 在全局工作區(qū)間內(nèi)共享樣式。這樣你就可以在一個(gè)文件中定義變量或者函數(shù)(mixins)并在你的其它組件文件中共享使用。這樣做是有好處的,但是很快你的變量命名就會(huì)與其它的變量名稱(chēng)相沖突(雖然它在另外一個(gè)全部空間下),你不可避免的會(huì)重構(gòu)你的 variables.scss 或者 settings.scss,最后你就會(huì)發(fā)現(xiàn)你已經(jīng)看不懂到底哪個(gè)組件依賴(lài)哪個(gè)變量了。最后的最后你會(huì)發(fā)現(xiàn)你的配置文件變量名稱(chēng)冗余到變得非常不實(shí)用。

針對(duì)上述問(wèn)題仍然是有更好的解決辦法的(事實(shí)上 Ben Smithett 的文章 Sass 和 Wepack 的混合使用 給了 CSS 模塊話(huà)很大的啟發(fā),我推薦大家去讀一讀這篇文章),但是不管怎么做你還是局限在了 Sass 的全局環(huán)境下。

CSS 模塊一次只運(yùn)行一個(gè)文件,這樣可以避免全局上下文的污染。而且像 JS 使用 import 或者 require 來(lái)加載依賴(lài)一樣,CSS 模塊使用 compose 來(lái)從另一個(gè)文件中加載:

/* colors.css */
.primary {
  color: #720;
}
.secondary {
  color: #777;
}
/* other helper classes... */
/* submit-button.css */
.common { /* font-sizes, padding, border-radius */ }
.normal {
  composes: common;
  composes: primary from "../shared/colors.css";
}

使用組件,我們能夠深入到每一個(gè)像colors.css一樣的基礎(chǔ)樣式表中,并隨意重命名它。又因?yàn)榻M件只是改變了最后導(dǎo)出的類(lèi)名稱(chēng),而不是 CSS 文件本身,composes 語(yǔ)句在瀏覽器解析之前就會(huì)被刪除。

/* colors.css */
.shared_colors__primary__fca929 {
  color: #720;
}
.shared_colors__secondary__acf292 {
  color: #777;
}
/* submit-button.css */
.components_submit_button__common__abc5436 { /* font-sizes, padding, border-radius */ }
.components_submit_button__normal__def6547 {}

事實(shí)上,當(dāng)它被瀏覽器解析之后,我們的局部是不存在一個(gè)"normal"樣式的。這是一件好事!這意味著我們可以增加一個(gè)局部名字有意義的對(duì)象(可能就叫"normal")而不用在 CSS 文件中新增代碼。我們使用的越多,對(duì)我們的網(wǎng)站會(huì)造成更少的視覺(jué)誤差以及在用戶(hù)瀏覽器上更少的不一致。

題外話(huà):空的類(lèi)樣式可以使用 csso 這樣的工具來(lái)檢查去除掉。

第四步:功能單一模塊

組件是非常強(qiáng)大的,因?yàn)樗_實(shí)的讓你描述了一個(gè)元素是什么,而不是它由那些樣式組成。這是一種不同的方式去描述概念示例(元素)到樣式實(shí)體(樣式規(guī)則)之間的映射關(guān)系。讓我們看一個(gè)簡(jiǎn)單的 CSS 例子:

.some_element {
  font-size: 1.5rem;
  color: rgba(0,0,0,0);
  padding: 0.5rem;
  box-shadow: 0 0 4px -2px;
}

這些元素,樣式都是特別簡(jiǎn)單的。然而也存在著問(wèn)題:顏色,字體大小,盒子陰影,內(nèi)邊距-這里的一切都是量身定制的,這讓我們想要在其它地方復(fù)用這些樣式的時(shí)候變得有些困難。下面讓我們用 Sass 重構(gòu)這些這些代碼:

$large-font-size: 1.5rem;
$dark-text: rgba(0,0,0,0);
$padding-normal: 0.5rem;
@mixin subtle-shadow {
  box-shadow: 0 0 4px -2px;
}

.some_element {
  @include subtle-shadow;
  font-size: $large-font-size;
  color: $dark-text;
  padding: $padding-normal;
}

這是一個(gè)進(jìn)化版,但是我們僅僅只達(dá)到了一部分目標(biāo)。事實(shí)上 $large-font-size$padding-normal 只是在名字上表示了它的用途,并不能在任何地方都執(zhí)行。像 box-shadow 這種定義沒(méi)辦法賦值給變量,我們不得不使用 mixin 或者 @extends 語(yǔ)法來(lái)配合。

CSS 模塊

通過(guò)使用組件,我們可以使用我們可復(fù)用的部分定義我們的組件:

.element {
  composes: large from "./typography.css";
  composes: dark-text from "./colors.css";
  composes: padding-all-medium from "./layout.css";
  composes: subtle-shadow from "./effect.css";
}

這種寫(xiě)法勢(shì)必會(huì)有很多單一功能文件產(chǎn)生,然而通過(guò)使用文件系統(tǒng)來(lái)管理不同用途的樣式比起用命名空間來(lái)說(shuō)要好的多。如果你想要從一個(gè)文件中導(dǎo)入多個(gè)類(lèi)樣式的話(huà),有一種簡(jiǎn)單的寫(xiě)法:

/* this short hand: */
.element {
  composes: padding-large margin-small from "./layout.css";
}

/* is equivalent to: */
.element {
  composes: padding-large from "./layout.css";
  composes: margin-small from "./layout.css";
}

這開(kāi)辟了一種可能,使用極細(xì)粒的類(lèi)樣式定義一些樣式別名去給每一個(gè)網(wǎng)站使用:

.article {
  composes: flex vertical centered from "./layout.css";
}

.masthead {
  composes: serif bold 48pt centered from "./typography.css";
  composes: paragraph-margin-below from "./layout.css";
}

.body {
  composes: max720 paragraph-margin-below from "layout.css";
  composes: sans light paragraph-line-height from "./typography.css";
}

我對(duì)這種技術(shù)非常感興趣,我覺(jué)得,它混合了像 Tachyons 類(lèi)似的 CSS 原子技術(shù),像 Semantic UI 那樣變量分離可讀的好處(譯者注:就是說(shuō) CSS 模塊的命名簡(jiǎn)單易懂,組件復(fù)用方便)。

但是 CSS 模塊化之路僅僅是剛剛開(kāi)始,未來(lái)我們希望大家能?chē)L試更多為它寫(xiě)出譜寫(xiě)出新的篇章。

翻滾吧!CSS 模塊!

我們希望 CSS 模塊化能有助于你和你的團(tuán)隊(duì)在你們現(xiàn)有的 CSS 和產(chǎn)品的基礎(chǔ)上維護(hù)代碼,讓它變得更舒適更高效。我們已經(jīng)接近可能的把額外的語(yǔ)法減少到最少,并盡量確保語(yǔ)法和現(xiàn)有的變化不大。我們有 Webpack, JSPM 和 Browserify 的示例代碼,如果你們使用它們中的其中之一,你們可以參考一二。當(dāng)然我們也在為 CSS 模塊話(huà)的使用尋找新的環(huán)境:服務(wù)端 NodeJS 的支持正在進(jìn)行,Rails 的支持已經(jīng)提上議程準(zhǔn)備進(jìn)行了。

但是為了讓它變得更簡(jiǎn)單,我在 Plunker 上制作了一個(gè)預(yù)覽示例,你不用安裝任何東西就可以運(yùn)行它:

這里是 CSS 模塊的 Github 倉(cāng)庫(kù)地址,如果你有任何問(wèn)題,請(qǐng)開(kāi) issue 提出。CSS 模塊團(tuán)隊(duì)還很小,我們還沒(méi)有看到一些有用的例子,歡迎你們給我們投稿。

最后的最后,祝大家開(kāi)心寫(xiě)樣式,幸福每一天!

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/85910.html

相關(guān)文章

  • H5多列布局

    摘要:多列布局基本概念多列布局類(lèi)似報(bào)紙或雜志中的排版方式,上要用以控制大篇幅文本。在網(wǎng)頁(yè)制作時(shí)采用層疊樣式表技術(shù),可以有效地對(duì)頁(yè)面的布局字體顏色背景和其它效果實(shí)現(xiàn)更加精確的控制。 多列布局 基本概念 1、多列布局類(lèi)似報(bào)紙或雜志中的排版方式,上要用以控制大篇幅文本。 2、跨列屬性可以控制橫跨列的數(shù)量 /*列數(shù)*/ -webkit-column-count: 3; /*分割線*/ -webkit...

    Jingbin_ 評(píng)論0 收藏0
  • H5多列布局

    摘要:多列布局基本概念多列布局類(lèi)似報(bào)紙或雜志中的排版方式,上要用以控制大篇幅文本。在網(wǎng)頁(yè)制作時(shí)采用層疊樣式表技術(shù),可以有效地對(duì)頁(yè)面的布局字體顏色背景和其它效果實(shí)現(xiàn)更加精確的控制。 多列布局 基本概念 1、多列布局類(lèi)似報(bào)紙或雜志中的排版方式,上要用以控制大篇幅文本。 2、跨列屬性可以控制橫跨列的數(shù)量 /*列數(shù)*/ -webkit-column-count: 3; /*分割線*/ -webkit...

    mayaohua 評(píng)論0 收藏0
  • 【轉(zhuǎn)】理解CSS模塊

    摘要:但是最終,我們會(huì)為模塊化帶來(lái)的好處而開(kāi)心模塊將作用域限制于組件中,從而避免了全局作用域的問(wèn)題。但這是因?yàn)槟K將樣式和組件相綁定,從而不會(huì)發(fā)生全局樣式的沖突。先從版本的模塊化開(kāi)始。我認(rèn)為模塊化背后的思想是正確的。 原文鏈接: https://www.sitepoint.com/und... 在瞬息萬(wàn)變的前端開(kāi)發(fā)世界中,很難找到一個(gè)真正有意義的概念,并且將其清晰明了的向廣大人民群眾普及。 ...

    Pines_Cheng 評(píng)論0 收藏0
  • 前端進(jìn)階(1) - CSS 模塊

    摘要:比如以為例,一個(gè)組件,包括一個(gè)文件一個(gè)文件圖片組件在中便可如下加載使用導(dǎo)出為對(duì)象的模塊化其實(shí),還有另外一種思路,就是將內(nèi)置中,成為的一部分。 CSS 模塊化 CSS(Cascading Style Sheets),從誕生之初就決定了它無(wú)法編程,甚至連解釋性語(yǔ)言都算不上,只能作為一種簡(jiǎn)單的層疊樣式表,對(duì) HTML 元素進(jìn)行格式化。 但隨著前端的發(fā)展,前端項(xiàng)目已經(jīng)變得越來(lái)越龐大和復(fù)雜,社區(qū)...

    lauren_liuling 評(píng)論0 收藏0
  • 前端進(jìn)階(1) - CSS 模塊

    摘要:比如以為例,一個(gè)組件,包括一個(gè)文件一個(gè)文件圖片組件在中便可如下加載使用導(dǎo)出為對(duì)象的模塊化其實(shí),還有另外一種思路,就是將內(nèi)置中,成為的一部分。 CSS 模塊化 CSS(Cascading Style Sheets),從誕生之初就決定了它無(wú)法編程,甚至連解釋性語(yǔ)言都算不上,只能作為一種簡(jiǎn)單的層疊樣式表,對(duì) HTML 元素進(jìn)行格式化。 但隨著前端的發(fā)展,前端項(xiàng)目已經(jīng)變得越來(lái)越龐大和復(fù)雜,社區(qū)...

    VishKozus 評(píng)論0 收藏0
  • CSS 模塊

    摘要:通過(guò)使用或者從中導(dǎo)入文件使得模塊被編譯成為可能。模塊一次只運(yùn)行一個(gè)文件,這樣可以避免全局上下文的污染。下面讓我們用重構(gòu)這些這些代碼這是一個(gè)進(jìn)化版,但是我們僅僅只達(dá)到了一部分目標(biāo)。 原文:http://glenmaddern.com/articl...譯者:@公子 如果你想知道 CSS 最近發(fā)展的轉(zhuǎn)折點(diǎn),你應(yīng)該選擇去觀看 Christopher Chedeau 在2014年11月的 N...

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

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

0條評(píng)論

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