level-8
CSS选择器常见的有几种?
- !important选择器——它是所有选择器里面权重最高的。
- *选择器——它是所有选择器里面权重最低的。可以为页面所有的标签添加统一样式,多用于页面整体样式调整,但它会增加浏览器的负荷,因为浏览器需要计算出页面所有的标签然后给这些标签添加样式,增加了页面的渲染时间;
- 标签选择器--可以为选择标签设置统一样式,比如设置
p{color:red;}
页面所有的段落颜色都是红色。 - id选择器——为页面单个标签设置属性,因为该属性只能在页面使用一次,所以只用来为重要的语义标签添加id属性。
- class选择器——为页面属性值为class的标签添加样式,因为可以多次反复的引用,所以使用频率很高。
p.user{font-size:18px;}
意思是为class属性值为‘user’的段落标签p设置样式为文本尺寸18px; - 属性选择器——通过为标签附加属性值来缩写选择范围,
input[type="text"]{color:blue;}
意思是为属性值type为text的input标签设置文本颜色为蓝色; - 组合选择器——通过父标签来选择后代标签元素为其添加样式
p span{color:purple;}
意思是选择p标签的所有span子元素并且为其设置颜色为purple。 - 伪类选择器——通过伪类设置选择范围,这种选择对于页面的变动性适应更好。
div p:first-of-type——选择div的所以子元素p中的第一个p;
div p:first-child——查找div的第一个子元素是否是p,如果是则匹配成功并为其添加样式,如果匹配不成功,则不起作用。
常见的这类属性:first-of-type;last-of-type;first-child;last-child;nth-of-type(n);nth-child(n);
选择器的优先级是怎样的?
选择器的优先级可以归纳为以下三条规则:
- 规则一、ID选择器的权重大于Class选择器,Class选择器的权重大于Element(元素)选择器;比如下面代码:
#div1 li{
color:blue;
}
.content .list li{
color:red;
} - 规则二、选择器的权重不区分加载先后顺序,如果是同级的权重,则后加载的样式覆盖先加载的;比如下面代码:
#div1{
color:red;
}
.content{
color:blue;
}虽然.content后加载,但是ID的权重高于Class。
- 规则三、继承的样式低于设置的样式;比如下面代码:
#div1{
color:red;
}
span{
color:blue;
}
<div id="div1">
<span>span1</span>
</div>虽然ID的权重高于Element的权重,但是ID是继承的样式,而Element(span)是设置的样式。
此外!important的优先级是最高的,*的优先级是最低的。
class和id的使用场景?
其实class和id的使用场景在规则中并没有给出规范,只是日常人们总结出来一些经验。
- id适合于页面板块切分时候的命名,因为页面板块的名称在页面中是独一无二的,是权重最高的。
- class适合于页面板块内部细节性的样式名命名,因为一个板块的样式可能是统一的,使用class可以很方便的重复使用。
使用class选择器时候为什么要划定适当的命名空间?
因为单纯的class选择器的范围太广泛,影响的标签太多,如果没有指定更具体的使用范围,引用时候就会出现很多意想不到的错误,比如本想修改div的字体大小,结果p因为样式需要引用的class也被修改了样式,如果是指定了这次修改是针对div的修改 div .style{font-size:16px;}
这样p的文本就不会被影响力。而且在团队协作时候,这种操作就越发的重要了。
/* 选择class属性值为header的标签 */
.header{
}
/* 选择class属性值为header的后代元素中class为logo的标签 */
.header .logo{
}
/* 选择同时具备class值为header和mobile的标签 */
.header.mobile{
}
/* 同时选择class值为header的后代p标签和class值为header的后代h3标签 */
.header p,.header h3{
}
/* 选择id值为header的后代元素中class值为nav的子元素li标签 */
#header .nav>li{
}
/* 选择id值为header的后代元素a的hover状态 */
#header a:hover{
}
列出你所知道的伪类选择器?
- :hover——鼠标悬停元素时候的样式;
- :active——鼠标点击元素时候的样式;
- :link——元素的常态样式;
- :actived——元素被点击过后的样式;
- :first-of-type——所选标签元素中的第一个使用样式;
- :nth-of-type(n)——所选标签元素中的第n个使用样式;
- :nth-child(n)——所选标签的父元素的第n个子元素使用样式;
- :last-of-type——所选标签元素中的最后一个使用样式;
- :first-child——所选标签元素的父元素的第一个子元素使用样式;
- :last-child——所选标签元素的父元素的最后一个子元素使用样式;
- focus——当元素获取焦点时候使用样式;
first-of-type和first-child的作用和区别?
俩者都可以选择标签,区别在于first-of-type表示所选标签的全部元素中的第一个,而first-child表示所选标签的父元素中所有子元素的第一个元素;
text-align:center的作用是什么,作用在什么元素上?能让是什么元素水平居中?
- text-align:center的作用是让行内元素水平居中;
- 作用在块级元素上;
- 能让块级元素的子元素中的行内元素水平居中;
如果遇到一个属性想知道兼容性,在哪里查看?
可以在网站caniuse查询。
level-8的更多相关文章
- Java compiler level does not match解决方法
从别的地方导入一个项目的时候,经常会遇到eclipse/Myeclipse报Description Resource Path Location Type Java compiler level d ...
- Android requires compiler compliance level 5.0 or 6.0. Found '1.4' instead的解决办法
今天在导入工程进Eclipse的时候竟然出错了,控制台输出的是: [2013-02-04 22:17:13 - takepicture] Android requires compiler compl ...
- Android版本和API Level对应关系
http://developer.android.com/guide/topics/manifest/uses-sdk-element.html Platform Version API ...
- [LeetCode] Binary Tree Level Order Traversal II 二叉树层序遍历之二
Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left ...
- [LeetCode] Binary Tree Zigzag Level Order Traversal 二叉树的之字形层序遍历
Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to ...
- [LeetCode] Binary Tree Level Order Traversal 二叉树层序遍历
Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, ...
- Android版本与api Level
Platform Version API Level VERSION_CODE Notes Android 4.4 19 KITKAT Platform Highlights Android 4.3 ...
- Selenium通过WebDriver控制IE浏览器出错 Browser zoom level was set to 109%. It should be set to 100%
错误信息: WebDriverException: Message: Unexpected error launching Internet Explorer. Browser zoom level ...
- pythonchallenge 解谜 Level 8
#-*- coding:utf-8 -*- #代码版本均为python 3.5.1 #Level 7 import bz2 un=b'BZh91AY&SYA\xaf\x82\r\x00\x00 ...
- pythonchallenge 解谜 Level 7
#-*- coding:utf-8 -*- #代码版本均为python 3.5.1 #Level 7 from PIL import Image x_begin, x_end = 0, 609 y_b ...
随机推荐
- 红外图像处理之直方图均衡的matlab源码与效果验证
红外图像是热辐射成像,由于场景中的目标与背景的温差相对较小,红外图像的动态范围大.对比度 低, 信噪比也较可见光图像的低.为了能够从红外图像中正确地识别出目标,必须对红外图像进行增强处理.一般红外探测 ...
- 转载:Network In Network学习笔记
转载原文1:http://blog.csdn.net/hjimce/article/details/50458190 转载原文2:http://blog.csdn.net/mounty_fsc/art ...
- yii rule
https://blog.csdn.net/ljfrocky/article/details/46373691 http://www.yiichina.com/tutorial/997 http:// ...
- [ Google APAC 2015 University Graduates Test ] Round C APAC Test
题目链接: http://code.google.com/codejam/contest/5214486/dashboard Problem A. Minesweeper 题目意思: 扫雷.告诉地雷所 ...
- Oracle raw数据类型
RAW的声明方式为RAW(L),L为长度,以字节为单位,它存数的是16进制的数据.作为数据库列最大2000,作为变量最大32767字节. RAW类型的好处就是:在网络中的计算机之间传输 RAW 数据时 ...
- PHP 可以获取客户端哪些访问信息
php是一种弱类型的程序语言,但是最web的 在程序语言中有系统全局函数: $_SERVER <?php echo "".$_SERVER['PHP_SELF'];#当前正在 ...
- EasyDSS流媒体服务器软件(支持RTMP/HLS/HTTP-FLV/视频点播/视频直播)-正式环境安装部署攻略
EasyDSS流媒体服务器软件,提供一站式的转码.点播.直播.时移回放服务,极大地简化了开发和集成的工作. 其中,点播功能主要包含:上传.转码.分发.直播功能,主要包含:直播.录像, 直播支持RTMP ...
- RabbitMQ指南之三:发布/订阅模式(Publish/Subscribe)
在上一章中,我们创建了一个工作队列,工作队列模式的设想是每一条消息只会被转发给一个消费者.本章将会讲解完全不一样的场景: 我们会把一个消息转发给多个消费者,这种模式称之为发布-订阅模式. 为了阐述这个 ...
- <2013 08 20> -----澳大利亚博士研究生申请-----
1.澳大利亚昆士兰大学博士的申请一年中什么时间都可以,但奖学金的评选每年只有四轮.和美国不同的是,在提交申请材料之前,个人必须联系好愿意接收你的导师,这个可以自己套磁联系,也可以和那边学院的小秘联系, ...
- Qt 如何获取一个文件的 Icon 图标?
#include <QPixmap> #include <QString> #include <QFileInfo> #include <QFileIconP ...