手记

04_CSS行高、盒子模型

CSS中的居中对齐

  • 内容居中对齐:text-align:center

  • 盒子居中对齐:margin:0 auto;

行高

  • 浏览器默认文字大小:16px
    行高:是基线与基线之间的距离

行高=文字高度+上下边距

   

注意:一行文字行高和父元素高度一致的时候,垂直居中显示。

  • 行高的单位

行高单位文字大小
20px20px20px
2em20px40px
150%20px30px
220px40px

总结:单位除了像素以为,行高都是与文字大小乘积。

父行高单位父元素文字大小子元素文字大小子行高
40px20px30px40px
2em20px30px40px
150%20px30px30px
220px30px60px

总结:
  上节已经讲过:行高大小会被继承
  不带单位时,行高是和子元素文字大小相乘,em和%的行高是和父元素文字大小相乘。行高以像素为单位,就是定义的行高值。
推荐行高使用像素为单位。

盒子模型

边框  border
  • Border-top-style:
      solid   实线
      dotted  点线
      dashed  虚线

  • Border-top-color   边框颜色

  • Border-top-width   边框粗细

        .box{             width: 300px;             height: 390px;             background: #999;             border-top-style: solid;    /*边框线型*/             border-top-color: red;      /*边框颜色*/             border-bottom-style: dotted;             border-bottom-color: green;                          border-left-color: yellow;             border-left-style: dashed;             border-left-width: 10px;         }

  • 边框属性的连写
    特点:没有顺序要求,线型为必写项。

border-right: blue solid 5px;

  • 四个边框值相同的写法

border: blue solid 5px;

特点:没有顺序要求,线型为必写项。

边框合并

border-collapse:collapse;

<head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         table{             width: 500px;             height: 300px;             border:red solid 1px;             border-collapse: collapse;         }         td{             border:red solid 1px;         }     </style> </head> <body>     <table cellspacing="0">         <tr>             <td></td>             <td></td>             <td></td>             <td></td>         </tr>         <tr>             <td></td>             <td></td>             <td></td>             <td></td>         </tr>         <tr>             <td></td>             <td></td>             <td></td>             <td></td>         </tr>     </table> </body> </html>

     边框合并,细线表格        

<html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         .username{             border:0 none;             outline-style: none;/*去掉轮廓线,轮廓线就是当输入框获得焦点时的边框线 */             background: #eeccee;             border: 1px dashed green;         }         .username:focus{             background: #ddeedd;         }         .email{             border: 0 none;             outline-style: none;             border-bottom:  1px dotted red;         }         .search{             border: 0 none;             outline-style: none;             border:1px solid #999;             background: url('search.png') no-repeat right;         }     </style> </head> <body>     <label for="myuser">用户名:</label><input type="text" class="username" id="myuser"><br/>     邮箱:<input type="text" class="email"><br/>     搜索一下:<input type="text" class="search"> </body> </html>

特别注意:
  获取焦点
  轮廓线
  取消边框的兼容性好的写法
  label for id的用法

内边距

padding-left   |   right    |  top  |  bottom

    .box{             padding-left: 10px;             padding-right: 20px;             padding-top: 30xp;             padding-bottom: 50px;         }

  • padding连写

  • padding: 20px;   上右下左内边距都是20px

  • padding: 20px 30px;   上下20px   左右30px

  • padding: 20px  30px  40px;   上内边距为20px  左右内边距为30px   下内边距为40

  • padding:  20px  30px   40px  50px;   上20px 右30px  下40px  左  50px

  • 内边距撑大盒子的问题
    影响盒子宽度或高度的因素:
      内边距影响盒子的宽度或高度
      边框影响盒子的宽度或高度

盒子的宽度=定义的宽度+边框宽度+左右内边距

提问:

一个大盒子宽度500px,高度300px.一个小盒子宽度300px,高度150px.请画出让小盒子在大盒子内部居中。

<html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         .min{             width: 300px;             height: 150px;             background: #eeffee;         }         .box{             width: 300px;             height: 150px;             padding-left: 100px;             padding-top: 75px;             padding-bottom: 75px;             padding-right: 100px;             background: #ffeeff;         }     </style> </head> <body>     <div class="box">         <div class="min"></div>     </div> </body> </html>

       

  • 继承的盒子一般不会被撑大
    包含(嵌套)的盒子,如果子盒子没有定义宽度,给子盒子设置左右内边距,一般不会撑大盒子。(水平方向不会被撑大,垂直方向会)

练习
  • 新浪导航条

<html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         .nav{             height: 40px;             background: #eee;             border-top: 3px orange solid;             border-bottom:1px solid #aaa;         }         .nav-con{             width: 1000px;             /*background: #aaa;*/             height: 100%;             margin 0 auto;                      }         a{             font:12px 微软雅黑;             color: #444;             display: inline-block;             height: 40px;             text-decoration: none;             line-height: 40px;             padding: 0 12px;         }         a:hover{             background: #bbb;         }     </style> </head> <body>     <div class="nav">         <div class="nav-con">             <a href="#">设为首页</a>             <a href="#">手机新浪网</a>             <a href="#">移动客户端</a>         </div>     </div> </body> </html>

       

外边距

margin-left   | right  |  top  |  bottom

  • 外边距连写

  • margin: 20px;    上下左右外边距20PX

  • margin: 20px 30px;   上下20px  左右30px

  • margin: 20px  30px  40px;     上20px  左右30px   下  40px

  • margin: 20px  30px   40px  50px; 上20px   右30px   下40px  左50px

  • 垂直方向外边距合并
    垂直方向的两个盒子一个设置上外边距,一个设置下外边距,取的设置较大的值。

<html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         .one{             width: 200px;             height: 200px;             background: orange;             margin-bottom: 20px;         }         .two{             width: 200px;             height: 180px;             background: yellow;             margin-top: 50px;         }     </style> </head> <body>     <div class="one"></div>     <div class="two"></div> </body> </html>

1. 实践上上面两个盒子垂直方向间距只有50px;因为浏览器做了优化。
  2. 边距合并问题只发生在块级元素之间

  • 嵌套的盒子外边距塌陷
    嵌套的盒子,直接给子盒子设置处置方向外边距的时候,会发生外边距塌陷

<html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         .father{             width: 300px;             height: 300px;             background: pink;         }         .son{             width: 100px;             height: 100px;             background: yellow;             margin-top: 80px;         }     </style> </head> <body>     <div class="father">         <div class="son"></div>     </div> </body> </html>

     外边距塌陷

解决方法:
  1 给父盒子设置边框
  2 给父盒子overflow:hidden;
   bfc   格式化上下文

行内元素可以定义左右的内外边距,上下会被忽略掉。
行内块可以定义内外边距

Fireworks的基本使用

新建文件   ctrl+n
打开文件  ctrl+o
调出和隐藏标尺 ctrl+r
清除辅助线:  视图---辅助线----清除辅助线
放大镜  z   放大镜状态下alt+鼠标左键 缩小
抓手   快捷键   空格
测量距离:
  先拉出2根辅助线
  切换到指针工具
  将光标放到2根辅助线之间,按住shift键

练习
  • 行业动态


           

<html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         .news{             width: 238px;             height: 166px;             border: 1px solid #D9E0EE;             border-top: 3px solid #FF8400;             margin: 0 auto;         }         .news-title{             height: 35px;             line-height: 35px;             padding-left: 12px;             border-bottom: 1px solid #D9E0EE;         }         ul,li{             list-style: none;             margin: 0;             padding: 0;         }         ul{             margin-top: 8px;         }         li{             padding-left: 19px;             background: url('li_bg.jpg') no-repeat 9px 11px;             line-height: 23px;             font-size: 13px;         }         a{             text-decoration: none;         }         a:link{             color: #666;         }         a:hover{             color: blue;         }     </style> </head> <body>     <div class="news">         <div class="news-title">行业动态</div>         <ul>             <li><a href="#">这就是行业内的动态</a></li>             <li><a href="#">这就是行业内的动态</a></li>             <li><a href="#">这就是行业内的动态</a></li>             <li><a href="#">这就是行业内的动态</a></li>             <li><a href="#">这就是行业内的动态</a></li>         </ul>     </div> </body> </html>

  • 爱宠知识


           

<html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         body , ul , li{             margin: 0;             padding: 0;         }         .content{             width: 260px;             height: 327px;             margin: 0 auto;             border:  1px solid #009900;             background: url('bg.gif');         }         .content .title{             height: 23px;             margin: 10px 0px 5px 10px;             border-left: 4px solid #C9E143;             font: 16px 微软雅黑;             padding-left: 11px;             color: #fff;         }         ul{             background: #fff;             /*height: 279px;*/             margin-left: 10px;             margin-right: 10px;         }         ul,li{             list-style: none;         }         li{             height: 30px;             border-bottom: 1px dashed #999;             margin:0 10px;             background: url('tb.gif') no-repeat left center;             padding-left: 16px;         }         li a{             line-height: 31px;             text-decoration: none;             color: #0066CC;         }     </style> </head> <body>     <div class="content">         <div class="title">爱宠知识</div>         <ul>             <li><a href="#">其实养猫比养狗咬好的多</a></li>             <li><a href="#">其实养猫比养狗咬好的多</a></li>             <li><a href="#">其实养猫比养狗咬好的多</a></li>             <li><a href="#">其实养猫比养狗咬好的多</a></li>             <li><a href="#">其实养猫比养狗咬好的多</a></li>             <li><a href="#">其实养猫比养狗咬好的多</a></li>             <li><a href="#">其实养猫比养狗咬好的多</a></li>             <li><a href="#">其实养猫比养狗咬好的多</a></li>             <li><a href="#">其实养猫比养狗咬好的多</a></li>         </ul>     </div> </body> </html>

  • 个人资料


           

<html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         /*body{             margin: 0;             padding:0;         }*/         .content{             width: 208px;             height: 384px;             margin: 0 auto;             border:1px solid #CECECE;         }         .title{             background: #ECEDEE;             padding-left: 9px;             height: 25px;             font:12px/25px 微软雅黑;             color: #686868;         }         .content .pic{             width: 180px;             height: 180px;             border: 1px solid #CECECE ;             margin:10px 0px 11px 13px;         }         .content .blink{             height: 31px;             text-align: center;             font-size: 14px;             color: #9090AA;         }         .content .blink img{             margin-left: 10px;         }         .content .weibo{             height: 38px;             text-align: center;             border-bottom: 2px dotted #D1D1D1;             margin:0px 14px 15px 13px;         }         .content .weibo input{             background: #EEEEF2 url('vb.jpg') no-repeat 2px center;             width: 69px;             height: 23px;         }         .content .friend{             text-align: center;             margin-left: 13px;             margin-right: 14px;             /*border-bottom: 1px dotted #D1D1D1;*/         }         .content .friend input{             width: 69px;             height: 23px;             margin-bottom: 5px;         }     </style> </head> <body>     <div class="content">         <div class="title">             个人资料         </div>         <div class="pic">             ![](1.jpg)         </div>         <div class="blink">             V闪闪             ![](v.jpg)         </div>         <div class="weibo">             <input type="button" value="微博">         </div>         <div class="friend">             <input type="button" name="" value="加好友">             <input type="button" name="" value="发纸条">             <input type="button" name="" value="写留言">             <input type="button" name="" value="加关注">         </div>     </div> </body> </html>



作者:对方不想理你并向你抛出一个异常
链接:https://www.jianshu.com/p/48f52e9a2fe1


0人推荐
随时随地看视频
慕课网APP