CSSセレクタ

CSSセレクタ:CSS役割にラベルを指定することで、ラベルの名前はセレクタです。意味:どのコンテナを選択します。

技術の共有の写真

セレクタの構文

CSSセレクタ: 

図1に示すように、基本的なセレクタ構文

セレクタ タイプ 機能説明
*  ワイルドセレクタ  HTML要素のように、ドキュメントを選択
E  要素セレクタ HTML要素の指定されたタイプを選択します
#ID  IDセレクタ 指定にID属性値「ID」要素のいずれかのタイプを選択します
。クラス  クラスセレクタ 任意の型の「クラス」の指定されたクラス属性値に任意の数の要素を選択します
selector1、selectorN  グループセレクタ マッチングの選択されたセットの各要素と

 

2、レベルセレクタ構文

セレクタ タイプ 機能説明
E F 子孫セレクタ(セレクタが含まれています) Fの選択は、整合素子E内に含まれている要素およびFの整合要素をマッチ
E> F 子供セレクタ F子要素要素の一致を選択し、整合素子E F要素にマッチします
E + F 隣接兄弟セレクタ マッチした要素の選択の背後にあるFと一致要素F整合素子E直ちに位置
E〜F ユニバーサルセレクタ 配置されたすべてのマッチング整合素子F、E及び整合要素の後に選択されたF要素

 

3、動的擬似クラスセレクタ構文

セレクタ タイプ 機能説明
E:リンク リンク擬似クラスセレクタ   整合素子Eを選択し、ハイパーリンクが訪問されていないとして、一致要素が定義されます。一般的にリンクポイントを記述するために使用
E:訪問   リンク擬似クラスセレクタ 整合素子Eを選択し、一致要素がハイパーリンクとして定義され、訪問されました。一般的にリンクポイントを記述するために使用
E:アクティブ ユーザーの行動セレクタ 整合素子Eを選択し、マッチング要素がアクティブになります。一般的にリンクやボタンのポイントを記述するために使用
E:ホバー ユーザーの行動セレクタ 要素E.上でマッチング要素E、およびユーザーのマウスを選択 IE6とブラウザの下にのみサポートされています。ホバー
E:フォーカス ユーザーの行動セレクタ 整合素子Eを選択し、焦点照合要素を取得

 

図4に示すように、擬似ターゲットクラスセレクタ

セレクタ 機能説明
E:対象 一致するすべての要素にEを選択し、整合素子は、関連URLにあります

 

図5に示すように、言語擬似クラスセレクタは、サイトの多言語バージョンで使用することが特に好都合です

  指定された言語を一致させるために使用される要素。

  E:LANG(言語)

 

図6に示すように、UI要素状態擬似クラスセレクタ構文

セレクタ タイプ 機能説明
E:チェックします 選択された擬似クラスセレクタ 選択されたチェックボタンやラジオボタンのフォーム要素を一致させます
E:有効 有効擬似クラスセレクタ すべての試合有効にフォーム要素
E:無効 利用不可能状態擬似クラスセレクタ すべて無効にフォーム要素にマッチします

 7,结构伪类选择器使用语法

选择器 功能描述
E:first-child 作为父元素的第一个子元素的元素E。与E:nth-child(1)等同,(IE6不支持)
E:last-child 作为父元素的最后一个子元素的元素E。与E:nth-last-child(1)等同
   
E F:nth-child(n) [CSS3]选择父元素E的第n个子元素F。其中n可以是整数(1,2,3)、关键字(even,odd)、可以是公式(2n+1),而且n值起始值为1,而不是0.
E F:nth-last-child(n) [CSS3]选择父元素E的倒数第n个子元素F。此选择器与E:nth-child(n)选择器计算顺序刚好相反,但使用方法都是一样的,其中:nth-last-child(1)始终匹配最后一个元素,与last-child等同
E:nth-of-type(n) [CSS3]选择父元素内具有指定类型的第n个E元素
E:nth-last-of-type(n) [CSS3]选择父元素内具有指定类型的倒数第n个E元素
E:first-of-type [CSS3]选择父元素内具有指定类型的第一个E元素,与E:nth-of-type(1)等同
E:last-of-tye [CSS3]选择父元素内具有指定类型的最后一个E元素,与E:nth-last-of-type(1)等同
E:only-child [CSS3]选择父元素只包含一个子元素,且该子元素匹配E元素
E:only-of-type [CSS3]选择父元素只包含一个同类型子元素,且该子元素匹配E元素
E:root 选择匹配元素E所在文档的根元素。在HTML文档中,根元素始终是html,此时该选择器与html类型选择器匹配的内容相同
E:empty 选择没有子元素的元素,而且该元素也不包含任何文本节点

注:(1),“ul>li:nth-child(3)”表达的并不是一定选择列表ul元素中的第3个子元素li,仅有列表ul中第3个li元素前不存在其他的元素,命题才有意义,否则不会改变列表第3个li元素的样式。

(2),:nth-child(n)  中参数只能是n,不可以用其他字母代替。

(3),:nth-child(odd) 选择的是奇数项,而使用:nth-last-child(odd) 选择的却是偶数项

8,否定伪类选择器

选择器 功能描述
E:not(F) 匹配所有除元素F外的E元素

9,属性选择器语法

选择器 功能描述
[attribute] 用于选取带有指定属性的元素。
[attribute=value] 用于选取带有指定属性和值的元素。
[attribute~=value] 用于选取属性值中包含指定词汇的元素。
[attribute|=value] 用于选取带有以指定值开头的属性值的元素,该值必须是整个单词。
[attribute^=value] 匹配属性值以指定值开头的每个元素。
[attribute$=value] 匹配属性值以指定值结尾的每个元素。
[attribute*=value]

匹配属性值中包含指定值的每个元素。


 

CSS 选择符:

1)      id选择器(# myid)

2)      类选择器(.myclassname)

3)      标签选择器(div, h1, p)

4)      相邻选择器(h1 + p)

5)      子选择器(ul > li)

6)      后代选择器(li a)

7)      通配符选择器( * )

8)      属性选择器(a[rel = "external"])

9)      伪类选择器(a: hover, li:nth-child)

可继承的样式:

1)      font-size

2)      font-family

3)      color

4)      text-indent

不可继承的样式:

1)      border

2)      padding

3)      margin

4)      width

5)      height

优先级算法:

1)      优先级就近原则,同权重情况下样式定义最近者为准;

2)      载入样式以最后载入的定位为准;

3)      3.!important >  id > class > tag  

4)      important 比 内联优先级高,但内联比 id 要高

CSS3新增伪类举例:

1)      p:first-of-type  选择属于其父元素的首个 <p> 元素的每个 <p> 元素。

2)      p:last-of-type   选择属于其父元素的最后 <p> 元素的每个 <p> 元素。

3)      p:only-of-type  选择属于其父元素唯一的 <p> 元素的每个 <p> 元素。

4)      p:only-child     选择属于其父元素的唯一子元素的每个 <p> 元素。

5)      p:nth-child(2)  选择属于其父元素的第二个子元素的每个 <p> 元素。

6)      :enabled :disabled 控制表单控件的禁用状态。

7)      :checked         单选框或复选框被选中。

CSS3有哪些新特性?

1)    CSS3实现圆角(border-radius),阴影(box-shadow),

2)    对文字加特效(text-shadow、),线性渐变(gradient),旋转(transform)

3)    transform:rotate(9deg) scale(0.85,0.90) translate(0px,-30px) skew(-9deg,0deg);// 旋转,缩放,定位,倾斜

4)    增加了更多的CSS选择器  多背景 rgba 

5)    在CSS3中唯一引入的伪元素是 ::selection.

6)    媒体查询,多栏布局

7)    border-image

伪元素选择器

selection

[CSS4]应用于文档中被用户高亮的部分(比如使用鼠标或其他选择设备选中的部分)。(IE8及以下不支持)(火狐-moz-selection)

first-line

选择每个 <p> 元素的首行,并为其设置样式。

first-letter

选择每个 <p> 元素的首字母,并为其设置样式。

before

在每个 <p> 元素的内容之前插入新内容。(IE7及以下不支持)

after

在每个 <p> 元素的内容之后插入新内容。(IE7及以下不支持)

cue

匹配所选元素中的WebVTT提示。这可以用于在VTT轨道的媒体中使用字幕和其他线索。

backdrop

参见MDN相关介绍(nDos翻译)(兼容性很差不推荐使用)

placeholder

(兼容性很差不推荐使用)

marker

::marker伪元素 选择列表的前置标记,一般包含着重符号或数字。任何设置 display: list-item属性的元素或伪元素都能使用::marker  比如 <li> 和<summary> 元素。(兼容性很差不推荐使用)

spelling-error

表示浏览器标记为不正确拼写的文本段。(目前没有浏览器实现)

文法エラー

構文エラーテキストセグメントとして特定のブラウザで使用されます。(何のブラウザの実装はありません)

おすすめ

転載: www.cnblogs.com/zhuochong/p/11417626.html