欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    工程师必知必会盒模型与块状行内元素.docx

    • 资源ID:28105676       资源大小:94KB        全文页数:7页
    • 资源格式: DOCX        下载积分:8金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要8金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    工程师必知必会盒模型与块状行内元素.docx

    上海腾一研发部内部技术文档文档标题前端工程师必知必会.doc分类标签资料来源网络 URL修订历史2010-01-18由zhy收录前端工程师对这些东西要“想都不用想”就知道么* 盒模型外边距、内边距和边框之间的关系,IE < 8中的盒模型有什么不同。  * 块级元素与行内元素怎么用CSS控制它们、它们怎样影响周围的元素以及你觉得应该如何定义它们的样式  css 2.1标准: http:/www.w3.org/TR/CSS21/visuren.html http:/www.w3.org/TR/CSS21/visudet.html  中文详解:  如果想熟练把握DIV和CSS的布局方法,第一要对盒模型有足够的了解。每个HTML元素都可以看作一个装了东西的盒子,盒子里面的内容到盒子的边框之间的距离即填充(padding),盒子本身有边框(border),而盒子边框外和其他盒子之间,还有边界(margin),如图1所示。 图1 盒模型图解 填充、边框和边界都分为“上右下左”四个方向,既可以分别定义,也可以统一定义。CSS内定义的宽(width)和高(height),指的是填充以内的内容范畴,因此一个元素:实际宽度 = 左边界 + 左边框 + 左填充 + 内容宽度(width) + 右填充 + 右边框 + 右边界实际高度 = 上边界 + 上边框 + 上填充 + 内容高度(height) + 下填充 + 下边框 + 下边界例如有CSS定义如下: Html代码 1. #menu   2. background: #9cf;  3. margin: 20px;  4. border: 10px solid #039;  5. padding: 40px;  6. width: 200px;  7.    则其实际宽度如图2所示。 图2 元素总宽度的运算而对于Windows IE 5.x及更前的版本,把这个盒模型的定义搞错了,它认为:宽度(width)= 元素内容 + 填充 + 边框这个确实很容易搞错,很多对于盒模型定义没有深入了解的人也同样容易犯这个错误。例如: Html代码 1. #menu   2. width: 200px;  3. padding: 5px;  4. border: 1px solid #ccc;  5.    那么,在IE5.5中div实际内容的宽度将是200px-5px-1px-5px-1px=188px,而在Firefox、Opera及IE 6等浏览器内宽度则是200px。注意:工作在怪癖模式下的IE 7-将使用IE 5的盒模型,所以注意给文档一个正确的DTD说明!这正是很多新手发觉自己定义的页面在不同的浏览器内看会发生错位的原因之一。因此就需要采取一定的补偿措施,一样可以避免同时定义元素的宽度和填充、边框,而将一些定义放到元素的子元素内定义。如果必须同时定义这几个值,也可以使用一些手段来校正这个错误,即俗称的css hack,其基本思想就是为没有错误的浏览器提供一个正确的宽度值,而对IE5.5等有问题的浏览器提供另一个值。例如如下的写法: Html代码 1. #menu   2. padding: 5px;  3. width:110px;  4. voice-family: """"  5. voice-family: inherit;  6. width: 100px;  7.    定义中第一个width:110px,是IE 5.5认为的元素的宽度,100px+5px+5px。 Html代码 1. voice-family: """"  2. voice-family: inherit;   是CSS2.0中的语音属性,由于Windows IE5.5不完全支持CSS2.0,不识别此属性,因此跳到下一个挑选符。但是其他浏览器(包括IE6)会连续解读下面的定义,由于css是“层叠”的,即对于同一个挑选符的相同的属性,后面的定义会覆盖掉前面的定义,因此,对于其他的浏览器,#menu的宽度为最后的100px。另一个常用的hack手法是使用!important(声明),声明加在CSS属性定义的后面,此条属性的级别将变成最高,即使后面有相同的定义也不会覆盖掉声明过的定义,不过IE不支持!important。例如有如下css定义: Html代码 1. #box   2. border: 1px solid #B51C8C;  3. width:768px;  4.    而其修正方法如图3所示。图3 针对IE修正CSS对于支持!important的浏览器,将接受width:768px,而ie6虽然不支持!important,但是由于其无法说明“ /*/(空注释)”,因此会忽略后面的定义,而ie 5.5却会接受最后定义的width:770px,因此达到修正的目的。关于盒模型,还有以下几点需要注意:对于块级元素(display:block),未浮动的垂直相邻元素的上边界和下边界会被压缩,例如:有上下2个元素,上元素的下边界为5px,下面元素的上边界为20px,则实际2个元素的间距为20px(2个边界值中较大的值)。如图4所示。 图4 边界的压缩注1. 块级元素(display: block)每个块级元素都从一个新行开始,而且其后的元素也需另起一行开 始,标题、段落、表格、层、body等都是块级元素。块级元素只能作为其他块级元素的子元素,而且需要一定的条件。 内联元素,例如<a>、<span>等,定义上下边界不会影响到行高(line-height),内联元素距离上一行元素的距离由行高决定,而不是填充或边界。 注2. 内联元素(display: inline)内联元素不需要在新行内显示,而且也不强迫其后的元 素换行,如a、em、span等都为内联元素。内联元素可以为任何其他元素的子元素。浮动元素(无论左或者右浮动)边界不压缩,且若浮动元素不声明宽度,则其宽度趋向于0,即压缩到其内容能承担的最小宽度。如果盒中没有内容,则即使定义了宽度和高度都为100%,实际上只占0%,因此不会被显示,此点在采取层布局的时候需特别注意。边界值可为负,其显示成效各浏览器可能不相同。填充值不可为负。边框默认的样式(border-style)为不显示(none)。

    注意事项

    本文(工程师必知必会盒模型与块状行内元素.docx)为本站会员(知****量)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开