中文字幕在线一区二区在线,久久久精品免费观看国产,无码日日模日日碰夜夜爽,天堂av在线最新版在线,日韩美精品无码一本二本三本,麻豆精品三级国产国语,精品无码AⅤ片,国产区在线观看视频

      如何搭建系統CSS架構

      時間:2024-09-26 09:37:37 系統架構師 我要投稿
      • 相關推薦

      如何搭建系統CSS架構

        css是英文Cascading Style Sheets的縮寫。 它是一種用來表現HTML(標準通用標記語言的一個應用)或XML(標準通用標記語言的一個子集)等文件樣式的計算機語言。那么如何搭建系統CSS架構呢,一起來學習學習!

        搭建CSS法則

        在項目開始的時候,我們談論了開發者關于他們的流程和痛點,并問他們的接口設計系統如何讓他們的工作量變簡單。

        完成我的前端指導問卷,這些導致一系列前端規則和系統封裝。這里有些我們創建的CSS具體規則。

        模塊化 —— 設計系統在每一個方面都是模塊,這是非常實用寫CSS的方法。這在組件之間需要清晰分隔。

        可讀性是關鍵 ——開發者必須在第一眼理解CSS代碼,并且理解每一個選擇器的目的。

        清晰勝過簡潔 —— 設計系統有時候看上去很冗長,但是作為交換,它提供清晰和韌性。保持CSS可讀性和可擴展性意味著犧牲簡潔的語法。

        保持平面化 —— 長的選擇器要回避,無論什么地方,盡可能保持CSS獨立DOM和模塊化。

        避免沖突 —— 因為組件會部署許多不同的應用,保證設計系統之間的CSS不會和其他的庫和系統有沖突,這很重要。通過系統空間命名Class名可以完成這個,更多的會在之后描述。

        從這些規則中,我們搭建了制約和語法,包含了這些規則,以滿足開發者的需求。這里有一個我們總結出的class語法:

        全局命名空間

        所有的Class都和設計系統關聯的都以全局命名空間為前綴,這就是公司名稱后面加一個連體符

        .cn-

        如果你工作的CSS框架是用于單個網站或者如果你對你的開發環境有絕對控制,那么引入全局命名空間是不需要的。但是如果你的設計系統是混合的技術,那么為系統特定代碼創建一個標識是很重要的。作為第三方開發者,在多個環境中利用他們的系統,營銷團隊可能會失控,因此Lightning Design System引用了相似的方法到他們的系統之中(通過前綴.slds-),在我們的例子中,許多我們客戶的開發者使用Angular,因此他們已經很熟悉命名空間的概念,因為Angular使用ng-作為命名空間,為Angular特殊的代碼。

        Class前綴

        除了命名空間,我們添加前綴到每個Class,為了使之更加明顯,這個這個Class是做什么的。下面是我們使用的類前綴:

        c- 用于UI組件,比如.cn-c-card 或.cn-c-header

        l- 用于布局相關樣式, 比爾.cn-l-grid__item或.cn-l--two-column

        u- 用于公共部分, 比如.cn-u-margin-bottom-double 或.cn-u-margin-bottom-double

        is- 和 has- 用于特定狀態, 比如.cn-is-active或 .cn-is-disabled. 適用于這些狀態為基礎的樣式。

        js- 用于目標特定功能, 比如.js-modal-trigger. 這些class沒有綁定樣式; 他們只是為了行為而保留的. 對于大多數案例, 這些 js- 類將在元素上會切換基于狀態的類。

        我被灌輸來自Harry Roberts的一個概念,并且一開始在我認為這有道理的同事,我還是持有質疑的態度的,僅僅因為這是額外的字符并且我認為前綴會降低代碼可讀性。然而我的想法是不對的。在實施類前綴之后,我發現他們對于分清每個類的角色十分有幫助并且對于破譯一個應用的代碼庫十分容易一目了然。對于設計系統用戶,這種清晰的代碼能夠整理清楚頭緒,特別有用。

        BEM語法

        BEM 代表了“塊元素修飾”,這意味著:

        Block 主要組件塊, 比如.cn-c-card或者.cn-c-btn

        Element 是主要塊的一個子類,比如.cn-c-card__title

        Modifier 是一個組件樣式的各種變化, 比如.cn-c-alert--error

        這種方法論已經很受歡迎了,將這些概念和全局命名空間和類前綴結合在一起,允許我們創造更明顯封裝的類名。

        把它們都放到一起:解剖一個類

        全局命名空間的結合,類別前綴,和BEM語法引出了一個明確的(是的,冗長的)類字符創,允許開發者們在構造UI的時候演繹他在之間扮演的角色。

        讓我們檢查下以下的例子:

        .cn-c-btn--secondary

        cn- 是來自設計系統的用于所有樣式的全局命名空間。

        c- 是class的類別, 在案例中,c- 一位置“組件”

        btn 是塊名(“Block(塊)” 就是BEM中的“B”)

        --secondary 是一個修飾成分, 指向一個塊的變化多端的樣式 (“Modifier(修飾)” 就是BEM中的“M”)

        這里有另一個例子:

        .cn-l-grid__item

        cn- 再一次出現就是系統的全局命名空間。

        l- 是類的類別, 在這種情況下l- 意味著 “布局”

        grid 是塊名

        __item 是一個元素, 表明那是塊中的一個分支(“Element”在BEM中指“E”)

        還有一個:

        .cn-c-primary-nav__submenu

        cn- 是系統的全局命名空間。

        c- 是類的類別, 在這個例子中c- 意味著 “component”

        primary-nav 是塊名

        __submenu是一個元素, 指出他是塊的子元素 (“Element” 在BEM中是“E”)

        此外,毫無疑問,這些類比大多數其他方法的類更加冗長,但是對于這種特殊的系統,這些約定很有意義。

        其他技巧

        明確細節

        為了防止代碼瓦解,我們詳細說明如何處理這么多細小的細節,就像注釋、代碼塊之間的空間距,tab還是space等等。感謝上天,Harry Roberts已經將一個極佳的綜合的資源整合在了一起,稱之為CSS Guidelines,對于這些類型的約定,這個作為我們的底線。我們梳理所有的代碼并且標記出我們偏離Harry指出地方的計劃。

        Sass父選擇器

        我一直有個關于CSS的一個問題,是找出究竟在哪里放一個規定的規則。如果我有一個主要的導航組件,我要把這些樣式放在頭部還是在部分的主要導航Sass?謝天謝地,Sass父元素原則器出現了,這允許我們把所有的組件特定的樣式放在一個根元素下:

        .cn-c-primary-nav {

        /**

        * Nav appearing in header

        * 1) Right-align navigation when it appears in the header

        */

        .cn-c-header & {

        margin-left: auto; /* 1 */

        }}

        這意味著,所有的主要導航樣式都可以在一個主導航Sass部分中找到,而不是將他們分成好幾個文件。

        Sass嵌套的明確規則

        在Sass中嵌套可能十分方便,但是增加了糟糕輸出的危險,會有過長的選擇器字符創。我們遵循《盜夢空間》規則,嵌套永遠不超過3層。

        牢記設計系統的CSS平坦規則,我們希望在下列情況中限制嵌套:

        一個樣式塊修飾

        媒體查詢

        父元素選擇器

        狀態

        樣式塊裝飾 對于裝飾來說,如果規則只有幾行長度,裝飾塊可以被嵌套在父元素中,就像下面這樣:

        .cn-c-alert {

        border: 1px solid gray;

        color: gray;

        /**

        * 錯誤彈出

        */

        &--error {

        border-color: red;

        color: red;

        }}

        由于&符號,這會編譯成:

        .cn-c-alert {

        border: 1px solid gray;

        color: gray;}.cn-c-alert--error {

        border-color: red;

        color: red;}

        對于長樣式塊,我們不會嵌套裝飾代碼,因為這減少了代碼的可讀性。

        媒體查詢器

        組件特定媒體查詢器能夠在組件塊中嵌套。

        .cn-c-primary-nav {

        /* Base styles */

        /**

        * 1) On larger displays, convert to a horizontal list

        */

        @media all and (min-width: 40em) {

        display: flex;

        }}

        這個會被編譯成:

        .cn-c-primary-nav {

        /* Base styles */}@media all and (min-width: 40em) {

        .cn-c-primary-nav {

        display: flex;

        }}

        父元素選擇器

        設計系統會充分使用Sass的父元素選擇器原理。這里允許所有的給定組件的規則在一個地方維護。

        .cn-c-primary-nav {

        /**

        * Nav appearing in header

        * 1) Right-align navigation when it appears in the header

        */

        .cn-c-header & {

        margin-left: auto; /* 1 */

        }}

        這會被編譯成:

        .cn-c-header .cn-c-primary-nav {

        display: flex;}

        cn-c-primary-nav所有樣式都會在一個地方找到,而不是分散在許多部分文件之中。

        狀態

        組件的狀態必須包括在一個嵌套的元素之中。這包括了hover, focus,和active狀態:

        .cn-c-btn {

        background: blue;

        &:hover, &:focus {

        background: red;

        }}

        這需要編譯為:

        .cn-c-btn {

        background: blue;}.cn-c-btn:hover, .cn-c-btn:focus {

        background: red;}

        狀態同樣可以選用通用類的形式,比如is-和 has-:

        .cn-c-accordion__panel {

        overflow: hidden;

        max-height: 0;

        &.cn-is-active {

        max-height: 40em;

        }}

        者會被編譯成:

        .cn-c-accordion__panel {

        overflow: hidden;

        max-height: 0;}.cn-c-accordion__panel.cn-is-active {

        max-height: 40em;}

        為了創建一個堅固的系統,將這些規則都放入一個地方中,給我們需要堅持的一些制約和規定。當我們遇到一些規定不是很明顯或者有多重解決方案的情況下,我們需要一次談話,討論如何處理這些問題,如果需要的話可以更新方針。


      【如何搭建系統CSS架構】相關文章:

      如何成為優秀的系統架構師06-03

      企業大規模系統整合架構如何選型10-27

      系統架構設計模式大全08-22

      系統架構師是做什么的12-30

      托福寫作高分框架如何搭建09-18

      圖書檢索系統體系架構研究12-05

      基于云架構的系統安全設計08-08

      系統架構師的就業前景分析01-11

      系統架構設計師要素01-11

      主站蜘蛛池模板: 日韩国产欧美成人一区二区影院| 久久婷婷国产精品简爱av| 国产主播一区二区在线观看 | 久久久午夜毛片免费| av在线免费观看你懂的| 99久久婷婷国产综合亚洲| 中文字幕第一页亚洲观看| 西丰县| 思茅市| 亚欧视频无码在线观看| 精品人妻av区乱码| 在线观看视频日本一区二区三区| 国产尤物二区三区在线观看| 久草免费在线播放视频| 久久精品国产亚洲av麻豆九月| 91热视频在线观看| 国产黑色丝袜在线观看视频| 日韩人妻中文字幕一区二区| 乐都县| 紫阳县| 曰韩久久精品中文字幕| 无码中文字幕专区一二三| 国产传媒剧情久久久av| 无码国产精品色午夜| 日产国产精品一区二区| 在线一区二区三区观看视频| 河西区| 熟女丝袜美腿亚洲一区二区三区| 贞丰县| 麻豆久久久国内精品| 在线天堂中文一区二区三区| 久久免费看少妇a级作爱片| 无码AV午夜福利一区| 国产AV高清精品久久| 亚洲大尺度动作在线观看一区| 国产美女直播一区二区| 天天摸天天做天天爽天天舒服| 亚洲乱码精品中文字幕| 国产爽片一区二区三区| 激情五月婷婷久久综合| 韩国女主播一区二区在线观看|