css选择器

元素选择器##

通配选择符*,类型选择符E, ID选择符#id, 类选择符.class

关系选择器##

包含选择符(E F): 选择E 的后代 F
子选择符(E > F):选择E 的子元素 F

相邻选择符(E + F):选择E 的兄弟节点F(紧邻,亲兄弟)
兄弟选择符(E ~ F):选择E 的所有兄弟元素F(包含堂兄弟)

属性选择器##

E[attr]: 选择具有attr属性的E元素
E[attr ='val']:选择具有attr属性且属性值等于val的E元素
E[attr~='val']: 选择具有attr属性,且值包含val的E元素(该属性具有一个或多个属性值,其中一个为val)
E[attr ^= 'val']:选择具有attr属性,且属性值为以val开头的字符串的E元素

<ul>
    <li class="abc">列表项目</li>
    <li class="acb">列表项目</li>
    <li class="bac">列表项目</li>
    <li class="bca">列表项目</li>
    <li class="cab">列表项目</li>
    <li class="cba">列表项目</li>
</ul>

<style>
li[class^="a"] {
    color: #f00;
}
</style>
Paste_Image.png

E[attr$='val']: 选择具有attr属性且属性值为以val结尾的字符串的E元素
E[attr*='val']: 选择具有attr属性且属性值为包含val的字符串的E元素
E[attr|='val']:选择具有attr属性且属性值为以val开头并用连接符-分隔的字符串的E元素,如果属性值仅为val,也将被选择

<ul>
    <li class="test1-abc">列表项目</li>
    <li class="test2-abc">列表项目</li>
    <li class="test3">列表项目</li>
    <li class="test3-abc">列表项目</li>
    <li class="test4-abc">列表项目</li>
    <li class="test5-abc">列表项目</li>
    <li class="test6-abc">列表项目</li>
</ul>
<style>
li[class|="test3"] {
    color: #f00;
}
</style>
Paste_Image.png

伪类选择器##

E:link (设置超链接a在未被访问前的样式)
E:visited(设置超链接a在其链接地址已被访问过时的样式)
E:hover(设置元素在其鼠标悬停时的样式)
E:active(设置元素在被用户激活(在鼠标点击与释放之间发生的事件)时的样式)

四种状态全部存在时需要有特定的书写顺序才能生效

a:link {}
a:visited {}
a:hover {}
a:active {}

E:focus(设置对象在成为输入焦点(该对象的onfocus事件发生)时的样式)
E:lang(fr)(匹配使用特殊语言的E元素)
E:not(s)匹配不含有s选择符的元素E
一个例子:

p:not(.class) {
    color: #f00;
}

E:root(匹配E元素在文档的根元素。在html中,根元素永远是html)

E:first-child(匹配父元素的第一个子元素,如果是E,则被选中
E:last-child(匹配父元素的最后一个子元素E)

这样理解:
  伪类选择符的构成: 被选中的元素E + 状态描述;

E:only-child(匹配父元素仅有的一个子元素E)
E:nth-child(n)(匹配父元素的第n个子元素E)

一个实践:用来实现奇偶选择:

<style>
li:nth-child(2n){color:#f00;} /* 偶数 ,等价于关键字even*/
li:nth-child(2n+1){color:#000;} /* 奇数 ,等价于关键字odd*/
</style>

<ul>
    <li>列表项一</li>
    <li>列表项二</li>
    <li>列表项三</li>
    <li>列表项四</li>
</ul>

E:nth-last-child(n)(匹配父元素的倒数第n个子元素E)

E:first-of-type(匹配同类型中的第一个同级兄弟元素E)
E:last-of-type(匹配同类型中的最后一个同级兄弟元素E)
E:only-of-type(匹配同类型中的唯一一个同级兄弟元素E)
E:nth-of-type(n)(匹配同类型中的第n个同级兄弟元素E)
E:nth-last-of-type(n)(匹配同类型中的倒数第n个同级兄弟元素E)

思考和上面一组选择器的区别?

E:empty(匹配没有任何子元素(包括text节点)的元素E)
E:checked(匹配用户界面上处于选中状态的元素E(radio和checkbox))
E:enabled(匹配用户界面上处于可用状态的元素E)
E:disabled(匹配用户界面上处于禁用状态的元素E(disabled属性))
E:target(匹配相关url指向的E元素)
作为锚点的目标元素跳转完成以后被选中

<style>
        .test-div{
            width: 500px;
            height:300px;

        }
        .test-div:target{
            border: 1px dotted red;
        }
    </style>
    <a href="#test4">test</a>
    <div class="test-div" id="test1"></div>
    <div class="test-div" id="test2"></div>
    <div class="test-div" id="test3"></div>
    <div class="test-div" id="test4"></div>
    <div class="test-div" id="test5"></div>

伪对象选择器##

E::first-letter(设置对象内的第一个字符的样式)
注意:此伪对象仅用于块级对象,内联对象无效
E::first-line(选择对象内的第一行, 同样仅作用于块级对象)
E::before(设置在对象前(依据对象树的逻辑结构)发生的内容,用来和content属性一起使用,并且必须定义content属性)

<style>
        p::before{
            content:"yes ,支持~";
        }
    </style>
    <p></p>

E::after(设置在对象后(依据对象树的逻辑结构)发生的内容,用来和content属性一起使用,并且必须定义content属性)
E::placeholder(设置对象文字占位符的样式(更改placeholder的文字样式))
注意:除了Firefox是 ::[prefix]placeholder,其他浏览器都是使用 ::[prefix]input-placeholder

Paste_Image.png

E::selection(设置对象被选择是的样式,只能定义被选择时的background-color, color,text-shadow)

<style>
        p::selection{
            color: orange;
        }
    </style>
    <p>选中我后看看发发生什么变化吧</p>
Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容