中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

CSS中優(yōu)先級和StackingContext等高級特性是什么-創(chuàng)新互聯(lián)

這篇文章將為大家詳細講解有關CSS中優(yōu)先級和Stacking Context等高級特性是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設,張家口企業(yè)網(wǎng)站建設,張家口品牌網(wǎng)站建設,網(wǎng)站定制,張家口網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,張家口網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。創(chuàng)新互聯(lián)公司專注于安定網(wǎng)站建設服務及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供安定營銷型網(wǎng)站建設,安定網(wǎng)站制作、安定網(wǎng)頁設計、安定網(wǎng)站官網(wǎng)定制、成都小程序開發(fā)服務,打造安定網(wǎng)絡公司原創(chuàng)品牌,更為您提供安定網(wǎng)站排名全網(wǎng)營銷落地服務。

CSS 優(yōu)先級

優(yōu)先級是瀏覽器是通過判斷哪些屬性值與元素最相關以決定并應用到該元素上的。優(yōu)先級僅由選擇器組成的匹配規(guī)則決定的。如果給一個P標簽增加一個類(Class),運行后Class 中的部分屬性并未發(fā)生改變,及CSS選擇器存在優(yōu)先級問題。

選擇符優(yōu)先級

常見的選擇器種類:

  • 內(nèi)聯(lián)樣式(Inline Style),如<span style="color:black">...</span>;
  • ID選擇符(ID selectors),如#id;
  • Class選擇符(Class),如 .class {...}、[href=‘’]、:hover;
  • 標簽選擇符(Tag),如 p,:before

每一類選擇器的權值不相同,各選擇器的優(yōu)先級是由權值決定的,

  • 內(nèi)聯(lián)樣式:1,0,0,0
  • ID 選擇符:1,0,0
  • Class 選擇符:1,0
  • Tag選擇符:1

CSS中優(yōu)先級和Stacking Context等高級特性是什么

來源優(yōu)先級順序,如圖所示

CSS中優(yōu)先級和Stacking Context等高級特性是什么

CSS中優(yōu)先級和Stacking Context等高級特性是什么

樣式系統(tǒng)從最右邊的選擇符開始向左進行匹配規(guī)則。只要當前選擇符的左邊還有其他選擇符,樣式系統(tǒng)就會繼續(xù)向左移動,直到找到和規(guī)則匹配的元素,或者因為不匹配而退出。

CSS 優(yōu)先級法則:

  1. 選擇器都有一個權值,權值越大越優(yōu)先;
  2. 當權值相等時,后出現(xiàn)的樣式表設置要優(yōu)于先出現(xiàn)的樣式表設置;
  3. 創(chuàng)作者的規(guī)則高于瀏覽者:即網(wǎng)頁編寫者設置的CSS 樣式的優(yōu)先權高于瀏覽器所設置的樣式;
  4. 繼承的CSS 樣式不如后來指定的CSS 樣式;
  5. 在同一組屬性設置中標有“!important”規(guī)則的優(yōu)先級大;

CSS常用模型

盒子模型(Box Model)就是在網(wǎng)頁設計中經(jīng)常用到的CSS技術所使用的一種思維模型。

CSS中優(yōu)先級和Stacking Context等高級特性是什么

盒子模型相關CSS屬性元素內(nèi)容(element content)、寬度及高度(Width/Height)、內(nèi)邊距(padding)、邊框(border) 和 外邊距(margin) 。

在 CSS 中,width 和 height 指的是內(nèi)容區(qū)域(element)的寬度和高度。增加內(nèi)邊距、邊框和外邊距不會影響內(nèi)容區(qū)域的尺寸,但是會增加元素框的總尺寸。假設框的每個邊上有 10 個像素的外邊距和 5 個像素的內(nèi)邊距。如果希望這個元素框達到 100 個像素,就需要將內(nèi)容的寬度設置為 70 像素。需要的屬性如下:

基本屬性

  • Width/Height
  • Padding
  • Margin
  • Boder
  • Outline
  • 偏移量屬性
    • Top/Left/Bottom/Right
  • 和.NET WinForm的區(qū)別:
    • 默認情況下Width/Height不包含Padding
    • Margin/Padding屬性的四個值的順序是top right bottom left (順時針)

所有東西可視為盒子模型

CSS中優(yōu)先級和Stacking Context等高級特性是什么

縱向Margin合并

如果<p>的縱向margin是12px,那么兩個<p>之間縱向的距離是多少?按常理來說應該是 12 + 12= 24px,但是答案仍然是 12px。因為縱向的margin是會重疊的,大的會覆蓋下的。

CSS中優(yōu)先級和Stacking Context等高級特性是什么

Position屬性規(guī)定元素的定位類型。這個屬性定義建立元素布局所用的定位機制。任何元素都可以定位,不過絕對或固定元素會生成一個塊級框,而不論該元素本身是什么類型。相對定位元素會相對于它在正常流中的默認位置偏移。以下是Posistion屬性取值范圍如下:

    • Static 普通流布局(Normal flow) ,默認值。沒有定位,元素出現(xiàn)在正常的流中(忽略 top, bottom, left, right 或者 z-index 聲明)。
    • Relative 支持偏移量屬性的普通流布局 ,生成相對定位的元素,相對于其正常位置進行定位。因此,"left:20" 會向元素的 LEFT 位置添加 20 像素。
    • Absolute 在容器元素內(nèi)絕對定位的布局 ,生成絕對定位的元素,相對于 static 定位以外的第一個父元素進行定位。元素的位置通過 "left", "top", "right" 以及 "bottom" 屬性進行規(guī)定。
    • Fixed 在顯示范圍內(nèi)的絕對定位布局,生成絕對定位的元素,相對于瀏覽器窗口進行定位。元素的位置通過 "left", "top", "right" 以及 "bottom" 屬性進行規(guī)定。

CSS中優(yōu)先級和Stacking Context等高級特性是什么

Float屬性

float 屬性定義元素在哪個方向浮動。以往這個屬性總應用于圖像,使文本圍繞在圖像周圍,不過在 CSS 中,任何元素都可以浮動。浮動元素會生成一個塊級框,而不論它本身是何種元素。

CSS中優(yōu)先級和Stacking Context等高級特性是什么

Stacking context

提供z-index??臻g特性并影響子元素渲染順序的結構,稱之為stacking context。

CSS中優(yōu)先級和Stacking Context等高級特性是什么

瀏覽器會給符合下面規(guī)則的dom元素分配一個Stacking context。

  • root元素(html)
  • 「已定位」元素(position: absolute or relative)且 指定z-index值非auto的元素
  • flex item且指定z-index值非auto的元素
  • opacity小于1的元素
  • 指定transform值非none的元素
  • 指定mix-blend-mode值非normal的元素
  • 指定filter值非none的元素
  • 指定isolation值為isolate的元素
  • 在will-change屬性上指定值為上述列表任意屬性的元素
  • 指定-webkit-overflow-scrolling值為touch的元素

z-index

CSS中優(yōu)先級和Stacking Context等高級特性是什么

Stacking order

  • 根據(jù)DOM樹結構,具有stacking context的元素會形成一個樹形結構。
  • 一個stacking context中的元素會根據(jù)z-index決定疊加順序。z-index大的靠前
  • z-index 0級元素中,有stacking context的元素的疊加順序靠前
  • 以上條件不能區(qū)分時,使用DOM樹中的順序決定疊加順序。

CSS中優(yōu)先級和Stacking Context等高級特性是什么

性能

CSS中優(yōu)先級和Stacking Context等高級特性是什么

像素渲染流水線

提升性能需要在構造流水線中每個元素都需要注意:

  • Style
    • 降低樣式選擇器的復雜度
    • 減少需要執(zhí)行樣式計算的元素的個數(shù)
  • Layout
    • 盡可能避免觸發(fā)布局
      • 幾乎所有的布局都是在整個文檔范圍內(nèi)發(fā)生的。
      • 使用flexbox替代老的布局模型
      • 避免強制同步布局事件的發(fā)生
      • 避免快速連續(xù)的布局
  • Paint
    • 除了transform和opacity之外,修改任何屬性都會觸發(fā)繪制
    • 提升移動或漸變元素的繪制層
    • 減少繪制區(qū)域
    • 簡化繪制的復雜度
CSS 選擇器性能
  • 一個選擇器的最右端是這個選擇器的關鍵條件(Key Selector)
  • 瀏覽器按照從右向左的方式匹配選擇器,因此應該將更具體的條件盡可能放在右端。
  • 避免使用*規(guī)則
  • 選擇器盡可能短
  • ID選擇符前面不要再加限定符
  • 沒必要用Tag選擇符限定Class選擇符

關于CSS中優(yōu)先級和Stacking Context等高級特性是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

本文標題:CSS中優(yōu)先級和StackingContext等高級特性是什么-創(chuàng)新互聯(lián)
網(wǎng)頁路徑:http://www.rwnh.cn/article10/cehcgo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設計公司、網(wǎng)站設計靜態(tài)網(wǎng)站、網(wǎng)站策劃、外貿(mào)建站、品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
叶城县| 红安县| 云南省| 苍梧县| 星子县| 阳山县| 开远市| 盐源县| 澜沧| 且末县| 赞皇县| 龙门县| 余姚市| 南和县| 咸丰县| 盈江县| 澄迈县| 凌源市| 浮山县| 台安县| 望城县| 沅陵县| 文水县| 辉县市| 内江市| 同心县| 尖扎县| 夏河县| 泗阳县| 雅安市| 井冈山市| 武宣县| 北票市| 固始县| 沐川县| 昌平区| 延安市| 曲沃县| 池州市| 大余县| 湘西|