Blogger Information
Blog 49
fans 0
comment 3
visits 23229
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
伪类选择器及盒模型示例
P粉479712293
Original
356 people have browsed it

题目一:伪类选择器示例

伪类选择器分两类:
1.结构伪类:根据元素的位置来获取元素。
2.状态伪类:根据元素的状态来获取元素。

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. <link rel="stylesheet" href="../static/4-4.css">
  8. <title>伪类选择器</title>
  9. </head>
  10. <body>
  11. <!-- *伪-就是假的意思 -->
  12. <!-- *类-class -->
  13. <!-- *以下是结构伪类,如先:ul.list>li{item$}*8 -->
  14. <ul class="list">
  15. <li>item1</li>
  16. <li>item2</li>
  17. <li>item3</li>
  18. <li>item4</li>
  19. <li>item5</li>
  20. <li>item6</li>
  21. <li>item7</li>
  22. <li>item8</li>
  23. </ul>
  24. </body>
  25. </html>

对应的css文件如下:

  1. /* *分组结构伪类 用于选择子元素 */
  2. /* *所有首先应该给它一个查询起点,就是首先要知道它爹是谁 */
  3. /* *对于第一项可以这样写 */
  4. .list>.first{
  5. background-color: violet;
  6. }
  7. /* *但现在我们不按以上这样写 */
  8. /* *第一项 */
  9. .list>li:first-of-type{
  10. background-color: violet;
  11. }
  12. /* *任意一项 */
  13. .list>li:nth-of-type(5){
  14. background-color: green;
  15. }
  16. /* *倒数第3项(不管增加多少项,保证是倒数第3项) */
  17. .list>li:nth-last-of-type(3){
  18. background-color: blue;
  19. }
  20. /* *最后一项(不管增加多少项,保证是最后一项) */
  21. .list>li:last-of-type{
  22. background-color: violet;
  23. }

效果图如下:


以上分别获取了第1项,第5项,倒数第3项,最后一项的元素。

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. <link rel="stylesheet" href="../static/4-4b.css">
  8. <title>结构伪类的参数</title>
  9. </head>
  10. <body>
  11. <ul class="list">
  12. <li>item1</li>
  13. <li>item2</li>
  14. <li>item3</li>
  15. <li>item4</li>
  16. <li>item5</li>
  17. <li>item6</li>
  18. <li>item7</li>
  19. <li>item8</li>
  20. </ul>
  21. </body>
  22. </html>

对应的css文件如下:

  1. /* *自选某个元素,即an+3 ,a=0*/
  2. .list>:nth-of-type(3){
  3. background-color: green;
  4. }
  5. /* *一组中从第4个元素开始 即n+4,a=1 */
  6. .list>:nth-of-type(n+4){
  7. background-color: green;
  8. }
  9. /* *选一组中只选前5个,即-n+5,a=-1 */
  10. .list>:nth-of-type(-n+5){
  11. background-color: green;
  12. }
  13. /* *选一组中只选最后2个,即-n+2,a=-1 */
  14. .list>:nth-last-of-type(-n+2){
  15. background-color: green;
  16. }
  17. /* *偶数行 */
  18. .list>:nth-of-type(2n){
  19. background-color: green;
  20. }
  21. /* *偶数行的另一方法 */
  22. .list>:nth-of-type(even){
  23. background-color: green;
  24. }
  25. /* *基数行 */
  26. .list>:nth-of-type(2n+1){
  27. background-color: green;
  28. }
  29. /* *基数行的另一方法 */
  30. .list>:nth-of-type(odd){
  31. background-color: green;
  32. }

效果图如下:

1.自选某个元素,即an+3 ,a=0

2.一组中从第4个元素开始 即n+4,a=1

3.选一组中只选前5个,即-n+5,a=-1

4.选一组中只选最后2个,即-n+2,a=-1

5.偶数行

6.基数行

3.状态伪类获取元素示例

  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  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. <link rel="stylesheet" href="../static/伪类选择器及盒模型示例3.css">
  8. <title>伪类选择器: 状态伪类</title>
  9. </head>
  10. <body>
  11. <form action="">
  12. <!-- *fieldset为表单分组标签 -->
  13. <fieldset>
  14. <!-- *legend为fieldset的标题标签 -->
  15. <legend>用户注册</legend>
  16. <label for="uname">用户名:</label>
  17. <input type="text" id="uname" />
  18. <!-- *如简化就用下面这两行,而删去上面这两行 -->
  19. <!-- <label>用户名:<input type="text" /></label>
  20. <br /> -->
  21. <!-- *提示 -->
  22. <label for="tips">警告:</label>
  23. <input type="text" id="uname" value="一旦注册禁止注销" disabled style="border: none" />
  24. <div class="gender">
  25. <label for="m">性别:</label>
  26. <input type="radio" name="sex" id="m" value="0" checked />
  27. <label for="m"></label>
  28. <input type="radio" name="sex" id="f" value="1" />
  29. <label for="f"></label>
  30. </div>
  31. <button>提交</button>
  32. </fieldset>
  33. </form>
  34. </body>
  35. </html>

对应的css文件如下:

  1. /* *获取被禁用的元素 */
  2. input:disabled {
  3. color: red;
  4. background-color: yellow;
  5. }
  6. /* *获取被默认选择中的单选按钮 */
  7. input:checked + label {
  8. color: red;
  9. }
  10. button {
  11. height: 30px;
  12. border: none;
  13. outline: none;
  14. background-color: seagreen;
  15. color: white;
  16. }
  17. /* *鼠标移入的状态变化 */
  18. button:hover {
  19. /* *光标 */
  20. cursor: pointer;
  21. background-color: coral;
  22. }
  23. /* *获得焦点时变化 */
  24. input:focus {
  25. background-color: cyan;
  26. }

效果图如下:

1.当打开页面时:

2.当输入框获得焦点时:

3.当选择单选框时:

4.当鼠标在按钮上方时:

题目二:盒模型示例

  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  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. <link rel="stylesheet" href="../static/伪类选择器及盒模型示例4.css">
  8. <title>盒模型/框模型</title>
  9. </head>
  10. <body>
  11. <div class="box"></div>
  12. </body>
  13. </html>

对应的css文件如下:

  1. /* *1. width */
  2. /* *2. height */
  3. /* * 3. padding */
  4. /* *4. border */
  5. /* *5. margin */
  6. .box {
  7. /* *宽度 */
  8. width: 200px;
  9. /* *高度 */
  10. height: 100px;
  11. /* *不可见,是因为没有设置:可见属性 */
  12. /* *可见属性: 背景, 边框 */
  13. background-color: violet;
  14. /* *背景裁切,只覆盖到内容区, 不包括padding */
  15. background-clip: content-box;
  16. border: 5px solid;
  17. /* *可见属性: 宽度, 样式, 颜色 */
  18. /* *padding: 内边距,是内容区与边框之间的填充物 */
  19. /* *margin: 外边距, 控制当前盒子与其它元素之间的空隙 */
  20. /* *不可见属性: margin, padding */
  21. padding: 20px;
  22. /* *margin: 20px; */
  23. /* *不可见的属性,只能设置宽度, 不能设置特征(颜色,样式) */
  24. /* *padding,margin: 就像空间,无色无味 */
  25. /* *当前的盒子在页面中实际占据的空间大小是: 250 * 150 */
  26. /* *我当前设置的盒子大小应该是: 200 * 100 */
  27. /* *宽,度各相差了 50px */
  28. /* *页面中计算盒子的实际宽高, 不包括 外边距: margin */
  29. /** 总宽度: */
  30. /* *border-left-width + padding-left + width + padding-right + border-right-width */
  31. /** 5 + 20 + 200 + 20 + 5 = 250px */
  32. /* *总高度: */
  33. /* *border-top-width + padding-top + height + padding-bottom + border-bottom-width */
  34. /* *5 + 20 + 100 + 20 + 5 = 150px */
  35. /* *我们的本意是: 我设置的宽高就应该是盒子的最终大小, */
  36. /* *而不是浏览器添加上内边距和边框后的计算大小 */
  37. /* *推荐的盒子大小计算方式,可以简化页面布局 */
  38. box-sizing: border-box;
  39. /* *还原到w3c默认标准盒子计算方式 */
  40. /* *box-sizing: content-box; */
  41. }
  42. .box {
  43. /* *border-top: 宽度 样式 前景色 */
  44. border-top: 10px dashed blue;
  45. border-left: 10px dashed blue;
  46. /* *四条边一样的时候,可以只写border */
  47. border: 5px solid red;
  48. }
  49. .box {
  50. /* *padding-left: 10px; */
  51. /* *padding-top: 5px; */
  52. /* *padding-right: 20px; */
  53. /* *简化方案: 顺时针方向 */
  54. /* *1. 四值: 顺时针, 上, 右,下,左 */
  55. padding: 5px 10px 15px 20px;
  56. /* *2. 三值, 中间永远表示左/右 */
  57. padding: 5px 10px 15px;
  58. /* *3. 双值, 第1个上下,第2个左右 */
  59. padding: 5px 10px;
  60. /* *三值,二值记忆方法: 第2个值永远表示左右 */
  61. /** 4. 单值, 四个方向全相同 */
  62. padding: 10px;
  63. }
  64. /** margin 的规则与padding完全一样 */

效果图如下:

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