我爱编程

学习JavaScript之css详解

2018-03-25  本文已影响0人  付凯强

1. CSS简介

p{
   font-size:12px;
   color:red;
   font-weight:bold;
}
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>认识CSS样式</title>
<style type="text/css">
p{
   font-size:20px;/*设置文字字号*/
   color:red;/*设置文字颜色*/
   font-weight:bold;/*设置字体加粗*/
}
</style>
</head>
<body>
<p>慕课网,超酷的互联网、IT技术免费学习平台,创新的网络一站式学习、实践体验;服务及时贴心,内容专业、有趣易学。专注服务互联网工程师快速成为技术高手!</p>
</body>
</html>
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>CSS样式的优势</title>
<style type="text/css">
span{
   color:blue;
}
</style>
</head>
<body>
    <p>慕课网,<span>超酷的互联网</span>、IT技术免费学习平台,创新的网络一站式学习、实践体验;<span>服务及时贴心</span>,内容专业、<span>有趣易学</span>。专注服务互联网工程师快速成为技术高手!</p>
</body>
</html>

2. CSS代码语法

CSS样式由选择符和声明组成,而声明又由属性和值组成。

p{
   font-size:12px;
   color:red;
}

3. CSS注释代码

<style type="text/css">
p{
   font-size:12px;/*设置文字字号为12px*/
   color:red; /*设置文字颜色为红色*/
}
</style>

4. 内联式CSS样式

从CSS 样式代码插入的形式来看基本可以分为以下3种:内联式、嵌入式和外部式三种。

<span style="color:blue">超酷的互联网</span>
<p style="color:red;font-size:12px">这里文字是红色。</p>
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>嵌入式css样式</title>
<style type="text/css">
span{
    color:blue;
}
</style>
</head>
<body>
    <p>慕课网,<span>超酷的互联网</span>、IT技术免费学习平台,创新的网络一站式学习、实践体验;<span>服务及时贴心</span>,内容专业、<span>有趣易学</span>。专注服务互联网工程师快速成为技术高手!</p>
</body>
</html>
<link href="base.css" rel="stylesheet" type="text/css" />
注意:
1、css样式文件名称以有意义的英文字母命名,如 main.css。
2、rel="stylesheet" type="text/css" 是固定写法不可修改。
3、<link>标签位置一般写在<head>标签之内。
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>嵌入式css样式</title>
<link href="style.css" rel="stylesheet" type="text/css" />
</head>
<body>
    <p>慕课网,<span>超酷的互联网</span>、IT技术免费学习平台,创新的网络一站式学习、实践体验;<span>服务及时贴心</span>,内容专业、<span>有趣易学</span>。专注服务互联网工程师快速成为技术高手!</p>
</body>
</html>
span{
   color:red;
   font-size:20px;
}

5. CSS样式优先级

  1. 嵌入式>外部式有一个前提:嵌入式css样式的位置一定在外部式的后面。
  2. 前提:内联式、嵌入式、外部式样式表中css样式是在的相同权值的情况下。

6. 选择器

body{
    font-size:12px;
    color:red;  
}
在{}之前的部分就是“选择器",比如右侧代码编辑器中第7行代码中的“body”就是选择器.

7. 标签选择器

<h1>勇气</h1>
去掉默认粗体:
<style type="text/css">
h1{
    font-weight:normal;
    color:red;
}
</style>

8. 类选择器

.stress{
    color:red;
}
<span class="stress">勇气</span>
1、英文圆点开头
2、其中类选器名称可以任意起名(但不要起中文)
1. <span>胆小如鼠</span>
2. <span class="stress">胆小如鼠</span>
3. .stress{color:red;}/*类前面要加入一个英文圆点*/
1. 
<span class="setGreen">公开课</span>
2. 
<style type="text/css">
.stress{
    color:red;
}
.setGreen{
    color:green;
}
</style>

9. ID选择器

1. 为标签设置id = “ID名称”,而不是class=“类名称”。
2. ID选择符的前面是“#”号,而不是英文圆点"."
<span id="stress">胆小如鼠</span>
#stress{
    color:red;
}

10. 类和ID选择器的关系

可以应用于任何元素
1. ID选择器只能在文档中使用一次,而类选择器可以使用多次。
2. 类选择器可以同时给一个元素设多个样式,而ID选择器不可以。
.stress{
    color:red;
}
.bigsize{
    font-size:25px;
}
<p>到了<span class="stress bigsize">三年级</span>下学期时,我们班上了一节公开课...</p>
  1. 子选择器
1. 大于符号(>),用于选择指定标签元素的第一代子元素.
2. 这行代码会使class名为food下的子元素li(水果、蔬菜)加入红色实线边框。
.food>li{border:1px solid red;}
  1. 包含(后代)选择器
1. 加入空格,用于选择指定标签元素下的后辈元素.
2. 代码会使第一段文字内容中的“胆小如鼠”字体颜色变为红色.
.first span{color:red;}
 <p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩,上课从来不敢回答老师提出的问题,生怕回答错了老师会批评我。就一直没有这个勇气来回答老师提出的问题。学校举办的活动我也没勇气参加。</p>
  1. 后含(后代)选择器与自选择器的区别
1. 子选择器(child selector)仅是指它的直接后代.
2. 后代选择器是作用于所有子后代元素
3. 后代选择器通过空格来进行选择,而子选择器是通过“>”进行选择
>  作用于元素的第一代后代,空格作用于元素的所有后代
  1. 通用选择器
* {color:red;}
* {font-size:20px;}
  1. 伪类选择器
a:hover{
    color:red;
    font-size:20px;
}
<a href="http://www.imooc.com">胆小如鼠</a>
上面一行代码就是为 a 标签鼠标滑过的状态设置字体颜色变红
  1. 关于伪类选择器
关于伪类选择符,到目前为止,可以兼容所有浏鉴器的“伪类选择符”就是 a 标签上使用 :hover 了(其实伪类选择符还有很多,尤其是 css3 中,但是因为不能兼容所有浏览器,本教程只是讲了这一种最常用的)。其实 :hover 可以放在任意的标签上,比如说 p:hover,但是它们的兼容性也是很不好的,所以现在比较常用的还是 a:hover 的组合。
  1. 分组选择符
h1,span{color:red;}
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>分组选择符</title>
<style type="text/css">
h1,span{color:red;}
.first,#second span{color:green;}
</style>
</head>
<body>
    <h1>勇气</h1>
    <p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩,上课从来不敢回答老师提出的问题,生怕回答错了老师会批评我。就一直没有这个勇气来回答老师提出的问题。学校举办的活动我也没勇气参加。</p>
    <p id="second">到了三年级下学期时,我们班上了一节公开课,老师提出了一个很<span>简单</span>的问题,班里很多同学都举手了,甚至成绩比我差很多的,也举手了,还说着:"我来,我来。"我环顾了四周,就我没有举手。</p>
    <img src="http://img.mukewang.com/52b4113500018cf102000200.jpg" >
</body>
</html>
  1. 继承
如某种颜色应用于p标签,这个颜色设置不仅应用p标签,还应用于p标签中的所有子元素文本,这里子元素为span标签。
p{color:red;}

<p>三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
p{border:1px solid red;}

<p>三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
给p标签设置了边框为1像素、红色、实心边框线,而对于子元素span是没用起到作用的

19. 特殊性(权值规则)

p{color:red;} /*权值为1*/
p span{color:green;} /*权值为1+1=2*/
.warning{color:white;} /*权值为10*/
p span.warning{color:purple;} /*权值为1+1+10=12*/
#footer .note p{color:yellow;} /*权值为100+10+1=111*/

20. 层叠

p{color:red;}
p{color:green;}
<p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>

21. 重要性

p{color:red!important;}
p{color:green;}
<p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
p 段落中的文本会显示的red红色
!important要写在分号的前面

22. 特别注意

23. CSS格式化排版

微软雅黑:且兼容性特别好
body{font-family:"Microsoft Yahei";}
.stress{
    font-size:20px;
    color:red;
}
<span class="stress">胆小如鼠</span>
a{font-weight:bold;}
<a href="http://www.imooc.com">批评</a>
p a{font-style:italic;}
p a{text-decoration:underline;}
.oldPrice{text-decoration:line-through;}
p{text-indent:2em;}
p{line-height:1.5em;}
h1{letter-spacing:20px;}
h1{word-spacing:50px;}
居中:text-align:center;
居左:text-align:left;
居右:text-align:right;

24. CSS盒模型

<div>、<p>、<h1>...<h6>、<ol>、<ul>、<dl>、<table>、<address>、<blockquote> 
、<form>
<a>、<span>、<br>、<i>、<em>、<strong>、<label>、<q>、<var>、<cite>、<code>
<img>、<input>

25. 内敛元素变块状元素

  1. 每个块级元素都从新的一行开始,并且其后的元素也另起一行。
  2. 元素的高度、宽度、行高以及顶和底边距都可设置。
  3. 元素宽度在不设置的情况下,是它本身父容器的100%(和父元素的宽度一致),除非设定一个宽度。
a{display:block;}

26. 块状元素变内联元素

 div{
     display:inline;
 }
<div>我要变成内联元素</div>
  1. 和其他元素都在一行上;
  2. 元素的高度、宽度及顶部和底部边距不可设置;
  3. 元素的宽度就是它包含的文字或图片的宽度,不可改变。

27. 其他元素变内联块状元素

  1. 和其他元素都在一行上;
  2. 元素的高度、宽度、行高以及顶和底边距都可设置。
在右边的代码编辑器中大家可以看到我们为 a 元素设置了宽和高,但都没有起到作用,原因是a在默认的时候是内联元素,内联元素是不可以设置宽和高的。
display:inline-block;
a{
    display:inline-block;
    width:20px;/*在默认情况下宽度不起作用*/
    height:20px;/*在默认情况下高度不起作用*/
    background:pink;/*设置背景颜色为粉色*/
    text-align:center; /*设置文本居中显示*/
}
<a>1</a>

28. 盒模型-边框(一)

div{
    border:2px  solid  red;
}
div{
    border-width:2px;
    border-style:solid;
    border-color:red;
}
dashed(虚线)| dotted(点线)| solid(实线)
border-color:#888;//前面的井号不要忘掉。
thin | medium | thick(但不是很常用),最常还是用象素(px)。

29. 盒模型-边框(二)

div{border-bottom:1px solid red;}

30. 盒模型-宽度和高度

div{
    width:200px;
    padding:20px;
    border:1px solid red;
    margin:10px;    
}

30. 盒模型-填充

div{
   padding-top:20px;
   padding-right:10px;
   padding-bottom:15px;
   padding-left:30px;
}
div{padding:10px;}
div{padding:10px 20px;}

31. 盒模型-边界

div{
   margin-top:20px;
   margin-right:10px;
   margin-bottom:15px;
   margin-left:30px;
}
div{ margin:10px;}
div{ margin:10px 20px;}

32. CSS布局模型

  1. 流动模型(Flow)
  2. 浮动模型 (Float)
  3. 层模型(Layer)

33. 流动模型

  1. 块状元素都会以行的形式占据位置。
三个块状元素标签(div,h1,p)宽度显示为100%
  1. 内联元素都会在所处的包含元素内从左到右水平分布显示。
内联元素标签a、span、em、strong都是内联元素
<a href="http://www.imooc.com">www.imooc.com</a><span>强调</span><em>重点</em>
<strong>强调</strong>

34. 浮动模型

div{
    width:200px;
    height:200px;
    border:2px red solid;
    float:left;
}
<div id="div1"></div>
<div id="div2"></div>
div{
    width:200px;
    height:200px;
    border:2px red solid;
    float:right;
}
div{
    width:200px;
    height:200px;
    border:2px red solid;
}
#div1{float:left;}
#div2{float:right;}

35. 层模型

  1. 绝对定位(position: absolute)

  2. 相对定位(position: relative)

  3. 固定定位(position: fixed)

36. 绝对定位(相对于父标签或浏览器)

div{
    width:200px;
    height:200px;
    border:2px red solid;
    position:absolute;
    left:100px; //相对于左边
    top:50px; 
}
<div id="div1"></div>

37. 相对定位(相对于以前位置)

#div1{
    width:200px;
    height:200px;
    border:2px red solid;
    position:relative;
    left:100px;
    top:50px;
}

<div id="div1"></div>
<body>
    <div id="div1"></div><span>偏移前的位置还保留不动,覆盖不了前面的div没有偏移前的位置</span>
</body>
以前的位置仍保留.png

38. 固定定位

相对于浏览器视图向右移动100px,向下移动50px。并且拖动滚动条时位置固定不变。
#div1{
    width:200px;
    height:200px;
    border:2px red solid;
    position:fixed;
    left:100px;
    top:50px;
}
<p>文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本。</p>
实现浏览器视图右下角定位div层:
position:fixed;
bottom:0;
right:0;

39. Relative与Absolute组合使用

box1是box2的父元素
<div id="box1"><!--参照定位的元素-->
    <div id="box2">相对参照元素进行定位</div><!--相对定位元素-->
</div>
#box1{
    width:200px;
    height:200px;
    position:relative;        
}
#box2{
    position:absolute;
    top:20px;
    left:30px;         
}
这样box2就可以相对于父元素box1定位了(这里注意参照物就可以不是浏览器了,而可以自由设置了)。
<div id="box3">
    <img src="http://img.mukewang.com/541a7d8a00018cf102000200.jpg">
    <div id="box4">当我还是三年级的学生时是一个害羞的小女生。</div>
#box3{
    width:200px;
    height:200px;
    position:relative;       
}
#box4{
    width:99%;
    position:absolute;  
    top:155px;
    
}

40. 盒模型代码简写

margin:10px 15px 12px 14px;/*上设置为10px、右设置为15px、下设置为12px、左设置为14px*/
margin:10px 20px 30px;

41. 颜色值缩写

p{color:#000000;}
p{color: #000;}
p{color: #336699;}
p{color: #369;}

42. 字体缩写

body{
    font-style:italic;
    font-variant:small-caps; 
    font-weight:bold; 
    font-size:12px; 
    line-height:1.5em; 
    font-family:"宋体",sans-serif;
}
body{
    font:italic  small-caps  bold  12px/1.5em  "宋体",sans-serif;
}
  1. 至少要指定 font-size 和 font-family 属性,其他的属性(如 font-weight、font-style、font-variant、line-height)如未指定将自动使用默认值。
  2. 缩写时 font-size 与 line-height 中间要加入“/”斜扛。

43. 颜色值

p{color:red;}
p{color:rgb(133,45,200);}
p{color:rgb(20%,33%,25%);}
每一项的值由 0-255 变成了十六进制 00-ff
p{color:#00ffff;}

44. 长度值

  1. 给定字体的 font-size 值,如果元素的 font-size 为 14px ,那么 1em = 14px;如果 font-size 为 18px,那么 1em = 18px
p{font-size:12px;text-indent:2em;}
  1. 当给 font-size 设置单位为 em 时,此时计算的标准以 p 的父元素的 font-size 为基础:
<p>以这个<span>例子</span>为例。</p>
p{font-size:14px}
span{font-size:0.8em;}
结果 span 中的字体“例子”字体大小就为 11.2px(14 * 0.8 = 11.2px)
p{font-size:12px;line-height:130%}
设置行高(行间距)为字体的130%(12 * 1.3 = 15.6px)

45. CSS样式设置小技巧

<body>
  <div class="txtCenter">我想要在父容器中水平居中显示。</div>
</body>
<style>
  .txtCenter{
    text-align:center;
  }
</style>
满足定宽和块状两个条件的元素是可以通过设置“左右margin”值为“auto”来实现居中的。
<body>
  <div>我是定宽块状元素,哈哈,我要水平居中显示。</div>
</body>
<style>
div{
    border:1px solid red;/*为了显示居中效果明显为 div 设置了边框*/
    
    width:200px;/*定宽*/    不可缺少
    margin:20px auto;/* margin-left 与 margin-right 设置为 auto */
}
</style>
margin-left:auto;
margin-right:auto;
  1. 加入 table 标签
  2. 设置display:inline方法:与第一种类似,显示类型设为行内元素,进行不定宽元素的属性设置。
  3. 设置position:relative和left:50%:利用相对定位的方式,将元素向左偏移50%,即达到居中的目的。
利用table标签的长度自适应性---即不定义其长度也不默认父元素body的长度(table其长度根据其内文本长度决定),因此可以看做一个定宽度块元素,然后再利用定宽度块状居中的margin的方法,使其水平居中。
1. 第一步:为需要设置的居中的元素外面加入一个 table 标签 ( 包括 <tbody>、<tr>、<td> )。
2. 第二步:为这个 table 设置“左右 margin 居中”(这个和定宽块状元素的方法一样)。
<div>
 <table>
  <tbody>
    <tr><td>
    <ul>
        <li>我是第一行文本</li>
        <li>我是第二行文本</li>
        <li>我是第三行文本</li>
    </ul>
    </td></tr>
  </tbody>
 </table>
</div>
<style>
table{
    border:1px solid;
    margin:0 auto;
}
</style>
<body>
<div class="container">
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</div>
</body>
<style>
.container{
    text-align:center;
}
/* margin:0;padding:0(消除文本与div边框之间的间隙)*/
.container ul{
    list-style:none;
    margin:0;
    padding:0;
    display:inline;
}
/* margin-right:8px(设置li文本之间的间隔)*/
.container li{
    margin-right:8px;
    display:inline;
}
</style>
它将块状元素的 display 类型改为 inline,变成了行内元素,所以少了一些功能,比如设定长度值
<body>
<div class="container">
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</div>
</body>
.container{
    float:left;
    position:relative;
    left:50%
}

.container ul{
    list-style:none;
    margin:0;
    padding:0;
    
    position:relative;
    left:-50%;
}
.container li{float:left;display:inline;margin-right:8px;}
</style>
  1. 好多报纸的文章标题在左右一侧时,常常会设置为垂直居中。
  2. 分为父元素高度确定的单行文本,以及父元素高度确定的多行文本。
单行:
<div class="container">
    hi,imooc!
</div>
<style>
.container{
    height:100px;
    line-height:100px;
    background:#999;
}
</style>
多行:
1. 使用插入 [table] (包括tbody、tr、td)标签,同时设置 vertical-align:middle
。
2. css 中有一个用于竖直居中的属性 vertical-align,在父元素设置此样式时,会对inline-block类型的子元素都有用
<body>
<table><tbody><tr><td class="wrap">
<div>
    <p>看我是否可以居中。</p>
</div>
</td></tr></tbody></table>
</body>
table td{height:500px;background:#ccc}
td 标签默认情况下就默认设置了 vertical-align 为 middle

46. 隐形改变display类型

 a 标签是 [行内元素],所以设置它的 width 是 没有效果的,但是设置为 position:absolute 以后,就可以了。
<div class="container">
    <a href="#" title="">进入课程请单击这里</a>
</div>
<style>
.container a{
    position:absolute;
    width:200px;
    background:#ccc;
}
</style>
[position : absolute]或者float:left 

47.后续

如果大家喜欢这篇文章,欢迎点赞;如果想看更多移动端后端Python方面的技术,欢迎关注!

上一篇下一篇

猜你喜欢

热点阅读