Css攻剋Selectors 一

来源:http://www.cnblogs.com/DarkInn/archive/2016/03/04/5242292.html
-Advertisement-
Play Games

Selectors (選擇器) ---------------參考MDN中css學習。 首先css選擇器有很多,但總體概括起來的話有兩種: 標簽選擇器(*是特殊情況),可但標簽,也可上下文多標簽; 屬性選擇器(id和class都是屬性,特殊的屬性); 標簽選擇器~單標簽 指此單個的標簽名字,使用時可


Selectors (選擇器)


 

---------------參考MDN中css學習。

首先css選擇器有很多,但總體概括起來的話有兩種:

  1. 標簽選擇器(*是特殊情況),可但標簽,也可上下文多標簽;
  2. 屬性選擇器(id和class都是屬性,特殊的屬性);

 標簽選擇器~單標簽

指此單個的標簽名字,使用時可直接用該標簽進行樣式操作,例如操作這段html中<strong>標簽里的值。

<!DOCTYPE html>
<html>
  <head>
  <meta charset="UTF-8">
  <title>Sample document</title>
    <link rel="stylesheet" href="style.css">
  </head>
  <body>
    <p>
      <strong>C</strong>ascading
      <strong>S</strong>tyle
      <strong>S</strong>heets
    </p>
  </body>
</html>

在css文件中使用它的標簽就能對標簽里的屬性進行樣式操作,比如讓字母變成紅色。

strong {
  color: red;
}

 


 

標簽選擇器~多標簽

 

 官方版

選擇器 選擇的元素
A E 任何是元素A的後代元素E (後代節點指A的子節點,子節點的子節點,以此類推)
A > E 任何元素A的子元素
E:first-child 任何元素的第一個子元素E
B + E 任何元素B的下一個兄弟元素E
B ~ E B元素後面的擁有共同父元素的兄弟元素E

通俗解釋版

  1. 選擇一個祖先的所有子孫節點,例如 div p{…}
  2. 選擇一個父元素的所有直屬節點,例如 div > p{…}
  3. 選擇某一個元素緊挨著的兄弟節點,例如 li + li{…}
  4. 選擇某一個元素的所有同胞節點,例如 span ~ a{…}
  5. 以上各種情況的組合應用(不要組合過於複雜,編碼講求可讀性第一)

 給大家列舉一個比較典型的應用,如下圖

  

  上圖中的效果應該比較常見,在各個菜單之間加下劃線。我之前的實現是:每個li都加一個border-bottom,在把最後一個li的border-bottom去掉。

  其實完全沒必要這樣麻煩,下麵一個樣式設置即可解決:

ul li+li{
    border-top: 1px solid #ccc;
}

慄子引用:http://www.cnblogs.com/wangfupeng1988/p/4282954.html


 

屬性選擇器~

最首先當然是要拿出兩位重量級選手了:class 和 id 

(Class selectors)

通過設置元素的 class 屬性,可以為元素指定類名。類名由開發者自己指定。 文檔中的多個元素可以擁有同一個類名。

在寫樣式表時,類選擇器是以英文句號(.)開頭的。

(ID selectors)

通過設置元素的 id 屬性為該元素制定ID。ID名由開發者指定。每個ID在文檔中必須是唯一的。

在寫樣式表時,ID選擇器是以#開頭的。

我們來看一個慄子:

<p class="key" id="principal">
.key {
  color: green;
}

#principal {
  font-weight: bolder;
}

上面的p標簽同時具有 class 屬性和id 屬性,

css中id選擇器principal必須是唯一的,而class選擇器卻是可以和其他標簽中的key相同,從而達到多個標簽同時操作。

你也可以將多個選擇器組合起來構成更確定的選擇器。

比如,選擇器.key 選中所有class屬性為 key的元素. 選擇器 p.key 選中所有class屬性為key的<p> 元素。

除了class 和 id,你還可以用方括弧的形式指定其他屬性。比如,選擇器 [type='button'] 選中所有 type 屬性為 button 的元素

 

實例: 使用類選擇器和ID選擇器

  1. 創建一個HTML文件
  2. 創建style1.css
<!doctype html>
<html>
  <head>
  <meta charset="UTF-8">
  <title>Sample document</title>
  <link rel="stylesheet" href="style1.css">
  </head>
  <body>
    <p id="first">
      <strong class="carrot">C</strong>ascading
      <strong class="spinach">S</strong>tyle
      <strong class="spinach">S</strong>heets
    </p>
    <p id="second">
          <strong>C</strong>ascading
          <strong>S</strong>tyle
          <strong>S</strong>heets
        </p>
  </body>
</html>
strong { color: red; }
.carrot { color: orange; }
.spinach { color: green; }
#first { font-style: italic; }

 

3.保存文件使用瀏覽器執行

重新組織樣式中規則的順序,你會發現改變這幾條規則的順序不會影響最終效果。

類選擇器 .carrot 和.spinach 比標簽選擇器 strong 擁有更高優先順序。

ID 選擇器 #first 比類選擇器和標簽選擇器更優先。

 


 

結尾:

第一篇先記錄這些吧,後面還有偽類和偽元素,個人還不是很懂,所以先學習學習在進行總結。

剛開始寫博客,還有很多的不足個人感覺節奏還是有點問題,希望各位海涵。我會慢慢優化,如有遺漏希望各位前輩指教,一定虛心學習 謝謝~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1 package com.shejimoshi.behavioral.Interpreter; 2 3 4 /** 5 * 功能:演奏文本 6 * 時間:2016年3月3日上午9:26:19 7 * 作者:cutter_point 8 */ 9 public class PlayContext 1
  • 在沒有瞭解到面向對象設計的7大原則前,我只是一隻豆子! 但豆子終將會成長不是嗎? 1.開閉原則:一個軟體實體應當對擴展開放,對修改關閉。也就是說在所涉及一個模塊的時候,應當使這個模塊可以在不被修改的前提下被擴展,即實現在不修改源代碼的情況下改變這個模塊的行為。 在開閉原則的定義中,軟體實體可以指一個
  • 定時器開之前一定要清,這是我之前疏忽的,導致頁面倒計時占用記憶體,頁面崩潰。
  • 文件夾treeview的效果 這樣的treeview在實際項目中使用的場景較多。 既然用的多,那就DIY一遍,雖沒有面面俱到,但也要將其基本實現完成一遍。 1.先準備圖標素材 file.gif,文件圖標 folder.gif,文件夾打開中的圖標 folder-closed.gif,文件夾關閉著的圖標
  • 針對BFC的特性之一:BFC之間互不影響原則,so,我們可以實現超級無敵的寬度自適應佈局。詳情見隨筆
  • 不廢話直接上代碼: HTML: <a class="js-tel tel" data-tel="1312414"></a> JS: 1 // zepto tel 2 $('body').on('tap', '.js-tel', function() { 3 var _this = $(this);
  • ---恢復內容開始--- JavaScript 計時器在JavaScript中,我們可以在設定的時間間隔之後來執行代碼,而不是在函數被調用後立即執行。計時器類型:一次性計時器:僅在指定的延遲時間之後觸發一次。間隔性觸發計時器:每隔一定的時間間隔就觸發一次。計時器方法: 計時器setInterval(
  • 最詳細的JavaScript和事件解讀 與瀏覽器進行交互的時候瀏覽器就會觸發各種事件。比如當我們打開某一個網頁的時候,瀏覽器載入完成了這個網頁,就會觸發一個 load 事件;當我們點擊頁面中的某一個“地方”,瀏覽器就會在那個“地方”觸發一個 click 事件。 這樣,我們就可以編寫 JavaScri
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...