Blogger Information
Blog 30
fans 1
comment 0
visits 16319
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
初识css:层叠样式表
moon
Original
462 people have browsed it

css:层叠样式表简介

css主要功能

  • 1.设定元素样式
  • 2.设定元素布局

    css基本工作流程

  • 1.查询:先找到元素,通过选择器进行选择
  • 2.设置元素样式,布局

    元素样式来源

    默认样式

  • 默认样式由浏览器默认

    自定义样式

  • 1.行内样式:写在标签内得style,例如下列代码
    1. <h1 style="color: red;">hello</h1>
    将得到如下结果
    行内样式
  • 2.文档样式:由<style>标签内代码决定,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <h1>hello</h1>
  11. <style>
  12. h1 {
  13. color: blue;
  14. }
  15. </style>
  16. </body>
  17. </html>

将得到如下结果:
文档样式

  • 3.外部样式:通过导入外部css文件代码决定,例如下列代码
  1. <head>
  2. <link rel="stylesheet" href="css/style1.css" />
  3. </head>
  4. <h1>hello</h1>

将导入css文件夹下的style1.css中的代码,style1.css文件代码如下:

  1. h1 {
  2. color: blueviolet;
  3. }

将获得如下结果:
外部眼样式

继承样式

  • 子级标签可以继承父级标签的颜色,字体,字号等样式
  • 子级标签无法继承父级标签的盒模型样式,例如border等样式无法被继承,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=>, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <div>
  11. <h1>hello </h1>
  12. <h3>color</h3>
  13. </div>
  14. <style>
  15. div {
  16. border: 1px solid #000;
  17. color: red;
  18. }
  19. </style>
  20. </body>
  21. </html>

h1,h3标签虽然没有指定样式,但是继承了父标签div的color样式,border无法被继承所以,h1,h3没有border样式,结果如下:
样式继承

基本选择器与上下文选择器

基本选择器

  • 1.通过标签选择,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <h1>hello</h1>
  11. <h2>color</h2>
  12. <style>
  13. h1 {
  14. color: red;
  15. }
  16. </style>
  17. </body>
  18. </html>

将选择将h1标签前景色设置成红色,结果如下:
基本选择器1

  • 2.通过元素各种属性进行选择,通常用id,class属性进行选择,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <h2 title="b">item1</h2>
  11. <h2 id="a">item2</h2>
  12. <h2 class="item3">item3</h2>
  13. <h2 class="item4">item4</h2>
  14. <h2 class="item5">item5</h2>
  15. <style>
  16. h2[title="b"] {
  17. color: red;
  18. }
  19. h2#a {
  20. color: blue;
  21. }
  22. h2.item3 {
  23. color:cornflowerblue
  24. }
  25. </style>
  26. </body>
  27. </html>

上述代码中h2[title="b"]将title属性等于”b”的h2元素指定前景颜色为红色,h2#a将id属性等于”a”的h2元素指定前景颜色为蓝色,h2.item3将class属性等于”item3”的h2元素指定前景颜色为浅蓝色,实际结果如下图:
基本选择器3

  • 3.群组选择,通过选择多个属性,来选择匹配元素,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <h2 title="b">item1</h2>
  11. <h2 id="a">item2</h2>
  12. <h2 class="item3">item3</h2>
  13. <h2 class="item4">item4</h2>
  14. <h2 class="item5">item5</h2>
  15. <style>
  16. h2#a,h2.item4,h2.item5 {
  17. color: blue;
  18. }
  19. </style>
  20. </body>
  21. </html>

上述代码中h2#a,h2.item4,h2.item5,选择了“id”为a的H2元素,class为item4的H2元素,class为item5的H2元素,将其前景颜色设置成蓝色,执行代码结果如下:
选择器4

  • 使用通配符*选择元素,如下代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <h2 title="b">item1</h2>
  11. <h2 id="a">item2</h2>
  12. <h2 class="item3">item3</h2>
  13. <h2 class="item4">item4</h2>
  14. <h2 class="item5">item5</h2>
  15. <style>
  16. body * {
  17. color: red;
  18. }
  19. </style>
  20. </body>
  21. </html>

上述代码中,body *,指定了body标签的所有子标签前景颜色设置为红色,执行代码结果如下:
选择器5

上下文选择器

  • 1.通过子元素进行选择,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <ul class="list">
  11. <li class="item">item1</li>
  12. <li class="item">item2</li>
  13. <li class="item">item3</li>
  14. <li class="item">item4</li>
  15. <li class="item">item5</li>
  16. </ul>
  17. <style>
  18. ul.list > li {
  19. color: red;
  20. }
  21. </style>
  22. </body>
  23. </html>

上述代码中ul.list > li,将指定class属性等于”list”的ul标签的所有li子元素的前景颜色设置成红色,执行代码如下图
选择器6

  • 2.通过所有后代进行选择,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <ul class="list">
  11. <li class="item">item1</li>
  12. <li class="item">item2</li>
  13. <li class="item">item3
  14. <li class="chirld">name1</li>
  15. <li class="chirld">name2</li>
  16. <li class="chirld">name3</li>
  17. <li class="chirld">name4</li>
  18. <li class="chirld">name5</li>
  19. </li>
  20. <li class="item">item4</li>
  21. <li class="item">item5</li>
  22. </ul>
  23. <style>
  24. ul.list li {
  25. color: red;
  26. }
  27. </style>
  28. </body>
  29. </html>

上述代码中ul.list li指定class属性等于”list”的ul标签的所有li后代元素的前景颜色设置成红色,执行代码如下图
选择器7

  • 通过相邻元素进行选择,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <ul class="list">
  11. <li class="item">item1</li>
  12. <li class="item vip">item2</li>
  13. <li class="item">item3
  14. <li class="chirld">name1</li>
  15. <li class="chirld">name2</li>
  16. <li class="chirld">name3</li>
  17. <li class="chirld">name4</li>
  18. <li class="chirld">name5</li>
  19. </li>
  20. <li class="item">item4</li>
  21. <li class="item">item5</li>
  22. </ul>
  23. <style>
  24. li.item.vip + * {
  25. color: red;
  26. }
  27. </style>
  28. </body>
  29. </html>

上述代码中li.item.vip + *指定了class属性为”item vip”的li元素的相邻代码的前景色设置成红色,执行结果如下图:
选择器8

  • 通过相邻元素进行选择,例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <ul class="list">
  11. <li class="item">item1</li>
  12. <li class="item vip">item2</li>
  13. <li class="item">item3
  14. <li class="chirld">name1</li>
  15. <li class="chirld">name2</li>
  16. <li class="chirld">name3</li>
  17. <li class="chirld">name4</li>
  18. <li class="chirld">name5</li>
  19. </li>
  20. <li class="item">item4</li>
  21. <li class="item">item5</li>
  22. </ul>
  23. <style>
  24. li.item.vip ~ * {
  25. color: red;
  26. }
  27. </style>
  28. </body>
  29. </html>

上述代码中li.item.vip ~ *指定了class属性为”item vip”的li元素的所有相邻代码的前景色设置成红色,执行结果如下图:
选择器9

选择器权重

权重作用

  • 在css代码中,出现同一个元素,被多个选择器选择,只有权重最高的选择器代码生效。
  • 权重让代码可以进行有效的升级,避免代码升级时反复修改代码

    权重计算方式

  • css将 id,class,tag看成一个”三位整数”,id -> 百位, class -> 十位, tag -> 个位,选择器每有一个tag,那么该选择器权重+1,每有一个class权重+10,每有一个id权重+100,将三者结果相加得到最终的权重
    例如下列代码
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>Document</title>
  8. </head>
  9. <body>
  10. <h1 id="a" class="b" title="c">hello</h1>
  11. <style>
  12. h1#a {
  13. color:blueviolet
  14. }
  15. body h1.b {
  16. color: springgreen;
  17. }
  18. body h1 {
  19. color: red;
  20. }
  21. h1 {
  22. color: blue;
  23. }
  24. </style>
  25. </body>
  26. </html>

上述代码中,h1#a,body h1.b,body h1,h1,都指定了同一个元素,但h1选择器权重为1,body h1选择器权重为2,body h1.b选择器权重为12,h1#a选择器权重为100,所以只有h1#a选择器生效了,代码最终执行结果如下:
选择器12

  • 实际项目中一般不推荐使用id,作为选择器,使用id会使该代码权重过高,导致代码更新较为麻烦,不具有弹性。
  • 实际项目中也不推荐使用tag,作为选择器,tag标签数量较少,而calss可以任意命名。
Correcting teacher:PHPzPHPz

Correction status:qualified

Teacher's comments:
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post