css(Cascading Style Sheet) 层叠样式表,定义了如何显示HTML元素,给HTML设置样式,让它看起来更好

一、css语法

  css样式包括两部门,选择器(给谁的样式)和声明(什么样)

css注释格式:  /*注释内容*/

二、css引入的三种方式

1、行内引入

style属性写在目标标签内

如: <p style=" color:red; ">hello world</p>

2、内部引入

style属性写在<head></head>标签内

 <head>
<meta charset="utf8" >
<title>标题</title>
<style>
p{background-color:red;}
</style>
</head> <body>
<p>hello world</p>
</body>

内部样式

3、外部引入(推荐)

外部引入是将css样式写在一个单独的文件中,然后在页面中引入

<link  href=''css样式文件路径'' rel=''stylesheet''  type="text/css"  />

三、css选择器

1、基本选择器

元素选择器    通过标签名来找

eg:  p { color : "red" ; }

ID选择器 通过设置id值来找

eg:  #p1 { color : "red" ; }

  <p id='p1'>hello word</p>

类选择器   通过设置class值来找

eg:  .c1 { color : "red" ; }

  <p class="c1" >hello word</p>

  注意:类名不要用数字开头,有的浏览器不认

通用选择器  *号表示所有的标签

eg:  * { color : "red"; }

2、组合选择器

后代选择器

  格式: 基本选择器 (空格)目标标签名 {  这里放css样式 }

  找基本选择器下的所有目标标签

儿子选择器

  格式 : 基本选择器>目标标签名 { 这里放css样式    }

  只找基本选择器下的第一层目标标签

毗邻选择器

  格式 : 基本选择器+目标标签名 {   这里放css样式  }

  找挨着基本选择器的下面的目标标签

弟弟选择器

  格式 : 基本选择器~目标标签名 {  这里放css样式   }

  找与基本选择器同一级的兄弟标签中的目标标签

3、属性选择器

格式 : 标签名[属性] {   这里放css样式    }

   或  标签名[属性=值] {   这里放css样式    }

给标签设置自定义的属性,通过自己自定义的方式来找。

还可以用正则来匹配自定义的属性。

4、分组和嵌套

#、分组

多个选择器之间用逗号隔开

eg:    div, p { color:" red " ; }

#、嵌套

多个选择器可以混合起来使用,如c1类内的p标签,组合选择器就属于嵌套使用。

eg:   .c1>p { color : " red " ; }

5、伪类选择器(css3新特性)

可以根据标签的不同状态再进行进一步的区分,比如一个a标签,点击前,点击时,点击后有不同的三个状态。

/* 未访问的链接 */
a:link {
color: #FF0000
} /* 已访问的链接 */
a:visited {
color: #00FF00
} /* 鼠标移动到链接上 */ 这个用的比较多
a:hover {
color: #FF00FF
} /* 选定的链接 */ 就是鼠标点下去还没有抬起来的那个瞬间,可以让它变颜色
a:active {
color: #0000FF
} /*input输入框获取焦点时样式*/
input:focus { #input默认的有个样式,鼠标点进去的时候,input框会变浅蓝色的那么个感觉
#outline: none;
background-color: blue; #框里面的背景色

伪类选择器

6、伪元素选择器

<p>你好哇,小可爱</p>

#first-leter 用来给首字母设置格式
p:first-letter{ font-size:32px; color:red} #before 在标签前插入内容
p:before {content:"内容"; color:"red";} #after 在标签后插入内容
p:after {content:"内容"; color:"red";}

伪元素选择器

注意:通过这个选择器添加的文本内容是无法选中的

7、选择器的优先级

  浏览器是从上往下加载文件的,当选择器相同时,按照先后顺序来决定样式,谁最后就按照谁渲染。当选择器不同是,由选择器的优先级,渲染优先级高的。

css继承:

  后代标签会继承父类标签的某些样式。如在body定义了字体的颜色,此页面上所有的标签都会继承body的字体颜色,但是这个权重是最低的,很容易被覆盖。

选择器优先级有不同选择器的权重决定:

  行内样式权重1000  >  id选择器100  >  类选择器10   >  元素选择器1 > css继承 权重0

day042 css 选择器的更多相关文章

  1. 前端极易被误导的css选择器权重计算及css内联样式的妙用技巧

    记得大学时候,专业课的网页设计书籍里面讲过css选择器权重的计算:id是100,class是10,html标签是5等等,然后全部加起来的和进行比较... 我只想说:真是误人子弟,害人不浅! 最近,在前 ...

  2. css选择器

    常用css选择器,希望对大家有所帮助,不喜勿喷. 1.*:通用选择器 * { margin: 0; padding: 0; } 选择页面上的全部元素,通常用于清除浏览器默认样式,不推荐使用. 2.#i ...

  3. dynamic-css 动态 CSS 库,使得你可以借助 MVVM 模式动态生成和更新 css,从 js 事件和 css 选择器的苦海中脱离出来

    dynamic-css 使得你可以借助 MVVM 模式动态生成和更新 css,从而将本插件到来之前,打散.嵌套在 js 中的修改样式的代码剥离出来.比如你要做元素跟随鼠标移动,或者根据滚动条位置的变化 ...

  4. CSS选择器的权重与优先规则?

    我们做项目的时候,经常遇到样式层叠问题,被其他的样式覆盖,或者写的权重不高没效果,对权重没有具体的分析,做了一个总结. css继承是从一个元素向其后代元素传递属性值所采用的机制.确定应当向一个元素应用 ...

  5. css选择器的使用详解

    -.css选择器的分类: 二.常用选择器详解: 1.标签选择器: 语法: 标签名 { 属性:属性值; } 代码示例: h1 { color: #ccc; font-size: 28px; } 2.类选 ...

  6. js,jq,css选择器

    js获取节点: var chils= s.childNodes; //得到s的全部子节点 var par=s.parentNode; //得到s的父节点 var ns=s.nextSbiling; / ...

  7. CSS系列:CSS选择器

    选择器(selector)是CSS中很重要的概念,所有HTML语言中的标记样式都是通过不同的CSS选择器来控制的.用户只需要通过选择对不同的HTML标签进行选择,并赋予各种样式声明,即可实现各种效果. ...

  8. 细说CSS选择器

    众所周知,CSS的一个核心特征就是能向文档中的一组元素类型应用某些规则.每个规则都有两个基本部分:选择器(selector)和声明块(declaration block).下图显示了规则的各个部分. ...

  9. CSS选择器 转

    来自于:http://www.cnblogs.com/webblog/archive/2009/08/07/1541005.html 最近在研究jQuery的选择器,大家知道jQuery的选择器和cs ...

随机推荐

  1. odoo中self的使用

    一:self是什么 目前新版的Odoo中使用到的self,是对  游标cr.用户ID.模型.上下文.记录集.缓存  的封装. 我们可以通过 self.XX 获取到这些封装的东西,比如:self.cr. ...

  2. spark-sql集合的“条件过滤”,“合并”,“动态类型映射DataFrame”,“存储”

    List<String> basicList = new ArrayList<String>(); basicList.add("{\"name\" ...

  3. varnish缓存系统基础知识

    缓存系统类型 1.页面缓存/pageCache     缓存静态资源(html js css image)  例如:varnish    squid 2.数据缓存/dataCache      缓存应 ...

  4. input type = file 上传图片转为base64

    项目背景是做图片识别,接口需要上传图片格式为base64格式的,react项目的相关代码: let reader = new FileReader();reader.readAsDataURL(e.t ...

  5. [py]一致性hash原理

    1,可变,不可变 python中值得是引用地址是否变化. 2.可hash 生命周期里不可变得值都可hash 3.python中内置数据结构特点 有序不可变 有序可变 无序可变 无序不可变 5.一致性h ...

  6. Kestrel:Net Core的跨平台服务器

    概述 Kestrel是一个基于libuv的跨平台ASP.NET Core web服务器,libuv是一个跨平台的异步I/O库.ASP.NET Core项目默认使用Kestrel作为web服务器. 用户 ...

  7. GDScript 格式化字符串

    GDScript offers a feature called format strings, which allows reusing text templates to succinctly c ...

  8. nginx根据CPU配置多线程运行

    转自:Nginx使用教程(二):Nginx配置性能优化之worker配置 配置Nginx workers <br\>NGINX根据指定的配置运行固定数量的工作进程. 这些工作进程负责处理所 ...

  9. ANNOTATION 注解

    注解(Annotation)很重要,未来的开发模式都是基于注解的,JPA是基于注解的,Spring2.5以上都是基于注解的,Hibernate3.x以后也是基于注解的,现在的Struts2有一部分也是 ...

  10. linux 安装nginx+php+mysql

    http://www.cnblogs.com/kyuang/p/6801942.htmlnginx安装 本文是介绍使用源码编译安装,包括具体的编译参数信息. 正式开始前,编译环境gcc g++ 开发库 ...