广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >CSS中盒模型用法的示例分析
  • 878
分享到

CSS中盒模型用法的示例分析

2024-04-02 19:04:59 878人浏览 泡泡鱼
摘要

CSS中盒模型用法的示例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。视觉类型的媒体根据CSS的视觉格式化模型(Visual fORMat

CSS中盒模型用法的示例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

视觉类型的媒体根据CSS的视觉格式化模型(Visual fORMatting model)的规则来处理文档树中的元素,从而将(X)html转化成制作者设计的样子。

例如:

如何生成元素框;
处理各元素之间的关系;
根据框的尺寸、定位等CSS属性来确定元素的位置等;
因此,要掌握使用CSS控制页面内元素的技巧,就需要深入了解框模型(Box Model)及视觉格式化模型的原理。

文档树中的元素都产生矩形的框(Box),这些框影响了元素内容之间的距离、元素内容的位置、背景图片的位置等等。而浏览器根据视觉格式化模型(Visual formatting model)来将这些框布局成访问者看到的样子。

视觉格式化模型中也有“布局(layout)”的概念,但是这个与页面设计经常用到的类似“3行2列”或者“3行3列”中的“排版布局”的概念不同,视觉格式化模型中的“布局”是指每个元素该如何来显示。

CSS 2.1中,一个控制框的布局可以根据三种定位方案:

常规流向。CSS 2.1中,常规流向包含块框的块格式化,行内框的行内格式化,块框或行内框的相对定位,以及插入框的定位。
浮动。在浮动模型中,一个框首先根据常规流向布局,再将它从流中取出并尽可能地向左或向右偏移。内容可以排列在一个浮动的边上。
绝对定位。在绝对定位模型中,一个框整个地从常规流向中脱离(它对后续的兄弟元素没有影响),并根据包含块来分配其定位。
在理解视觉格式化的概念之前,要明确一点:包含块(Containing Block)是视觉格式化模型的一个重要概念,它也可以理解为一个矩形,而这个矩形的作用是为它里面包含的元素提供一个参考,元素的尺寸和位置的计算往往是由该元素所在的包含块决定的。

框模型(Box model,也译作“盒模型”)是CSS非常重要的概念,也是比较抽象的概念。

文档树中的元素都产生矩形的框(Box),这些框影响了元素内容之间的距离、元素内容的位置、背景图片的位置等等。而浏览器根据视觉格式化模型(Visual formatting model)来将这些框布局成访问者看到的样子。

因此,要掌握使用CSS布局的技巧,就需要深入了解框模型和视觉格式化模型的原理。

浏览器内显示的元素都可以看作是一个装了东西的矩形的盒子,这些矩形的盒子嵌套、叠加或者并列在一起,形成了页面。

提示:“box model”往往被译为“盒模型”。但是盒子是具有厚度的,也就是说盒子是三维的,而框则没有厚度,是二维的,因此本书采用了“框模型”这个译法。

图1显示了每一个元素的“框(Box)”由几部分组成:
CSS中盒模型用法的示例分析

内容(content)
例如:文字、图片或者其他元素等,内容也可以看作是一个长方形的框,width(宽度)和height(高度)2个CSS属性设定的就是内容框的宽度和高度。
边框(border)
边框(也译为边界)是可以具体显示出来的,可以设定宽度、外观样式和颜色。
补白(padding)
补白(也译为填充、内边距、内补丁等)是内容框与边框之间的距离,补白部分显示的是背景。
边距(margin)
边距(也译为边白、外边距、外补丁等)是边框外的透明区域,用来设定本元素与其它元素之间的距离。
一个元素框,又有上、右、下、左四个方向的边,如图2所示。
CSS中盒模型用法的示例分析

由图2大家可以发现,1个元素所占的区域其实是由几个矩形框组成:元素的内容框、补白形成的框、元素的边框以及边距形成的框。这些框的边缘又有如下定义:

元素内容框的边缘,称为“内容边(content edge)”或“内边(inner edge)”,4条内容边形成“内容框(content box)”。
补白形成的框的外边缘,称为“补白边(padding edge)”,补白边围绕框的补白。如果补白宽度为0,则补白边和内容边重合。4条补白边形成“补白框(padding box)”。
边框形成的框的外边缘,称为“边框边(border edge)”。如果边框宽度为0,则边框边和补白边重合。4条边框边形成“边框框(border box)”。
边距形成的框的外边缘,称为“边距边(margin edge)”或“外边(outer edge)”,边距边围绕框的边距。如果边距宽度为0,则边距边和边框边重合。4条边距边形成“边距框(margin box)”。
内容框的尺寸(宽度和高度)取决于若干个因素,例如:

产生框的元素是否设定了width属性或height属性;
框是否包含文本或其它框;
框是否是一个表格等等。
例如下列代码(查看实例)其内容框与框之间的关系,如图3、图4所示。

  1. * { margin:0; padding:0; color:#666;}   

  2. div { border:4px solid #F90; background:#FC6;}   

  3. ul { list-style:none; margin:10px; padding:10px; background:#FC6;}   

  4. li { padding : 10px 0 10px 10px; background : #FF9;margin : 15px;}   

  5. .sample { margin-right:0; border:5px dashed #F90;}   

  6. <ul>   

  7.   <li>第1个li里面的示例文字示例文字</li>   

  8.   <li>第2个li里面的示例文字</li>   

  9. </ul>   

  10. <div>ul下面的div</div>  

CSS中盒模型用法的示例分析

CSS中盒模型用法的示例分析

由图3和图4,我们可以发现:

元素的框宽度 = 左边距(margin-left) + 左边框宽(border-left-width) + 左补白(padding-left) + 内容宽度(width) + 右补白(padding-right) + 右边框宽(border-right-width) + 右边距(margin-right)
元素的框高度 = 上边距(margin-top) + 上边框宽(border-top-width) + 上补白(padding-top) + 内容高度(height) + 下补白(padding-bottom) + 下边框宽(border-bottom-width) + 下边距(margin-bottom)
提示:关于margin在垂直方向重叠的情况,请参见本章[8.9.2.2 边距的重叠]一节。

在IE 5.5及更早的版本,以及在怪异模式中的IE 6.0/7.0中,会错误地将框模型理解为:

width = border-left + padding-left + 内容宽度 + padding-right + border-right
height = border-top + padding-top + 内容高度 + padding-bottom + border-bottom
也就是说,错误的框模型把width和height理解为边框框的宽度和高度,而不是内容框的。(当然,很多人都认为这样的设定更容易计算布局的尺寸。)

例如下列代码:

  1. div { width:300px; margin:10px; padding:15px; border:5px solid #ccc;}  

则div的框宽度应为360px(10px + 5px + 15px + 300px + 15px + 5px +10px),而在IE的错误框模型中,框的宽度为320px(10px + 300px +10px),实际的内容宽度为260px(300px &ndash; 15px*2 &ndash; 5px*2)。

因此会造成元素尺寸显示的不正确。

提示:在CSS 3中,制作者可以通过“box-sizing ”属性来指定width和height的值应用在内容框或者边框框上。

看完上述内容,你们掌握CSS中盒模型用法的示例分析的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网JavaScript频道,感谢各位的阅读!

--结束END--

本文标题: CSS中盒模型用法的示例分析

本文链接: https://www.lsjlt.com/news/81773.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • CSS中盒模型用法的示例分析
    CSS中盒模型用法的示例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。视觉类型的媒体根据CSS的视觉格式化模型(Visual format...
    99+
    2022-10-19
  • css盒模型的示例分析
    小编给大家分享一下css盒模型的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 1.各种盒模型 inline-blo...
    99+
    2022-10-19
  • CSS中盒子模型的示例分析
    这篇文章主要为大家展示了“CSS中盒子模型的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“CSS中盒子模型的示例分析”这篇文章吧。 所有HTML元素可...
    99+
    2022-10-19
  • css继承盒模型的示例分析
    这篇文章给大家分享的是有关css继承盒模型的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。继承盒模型让盒模型从html 继承:html {    &nbs...
    99+
    2023-06-27
  • CSS盒模型面试题的示例分析
    这篇文章主要介绍了CSS盒模型面试题的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、谈谈你对CSS盒模型的认识?问题简答所有 H...
    99+
    2022-10-19
  • css的盒模型实例分析
    这篇文章主要介绍“css的盒模型实例分析”,在日常操作中,相信很多人在css的盒模型实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css的盒模型实例分析”的疑惑有所帮...
    99+
    2022-10-19
  • HTML中盒模型的示例分析
    小编给大家分享一下HTML中盒模型的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!盒模型规定了元素框处理元素内容width与height值、内边距padding、边框border 和 外边距margin 的数值大小...
    99+
    2023-06-08
  • CSS盒子模型实例分析
    本篇内容介绍了“CSS盒子模型实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! CSS 盒子模型(...
    99+
    2022-10-19
  • css弹性盒模型中容器属性的示例分析
    小编给大家分享一下css弹性盒模型中容器属性的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2022-10-19
  • CSS盒子模型含义和原理的示例分析
    这篇文章主要介绍CSS盒子模型含义和原理的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是盒子模型说起盒子模型,作为前端开发的我们,相信大家都有了解过的 。这里套用mdn...
    99+
    2022-10-19
  • CSS盒子模型及box-sizing属性实例分析
    本文小编为大家详细介绍“CSS盒子模型及box-sizing属性实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“CSS盒子模型及box-sizing属性实例分析”文章能帮助大家解决疑惑,下面跟着小编...
    99+
    2022-10-19
  • css3中盒模型以及box-sizing属性的示例分析
    这篇文章主要为大家展示了“css3中盒模型以及box-sizing属性的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css3中盒模型以及box-siz...
    99+
    2022-10-19
  • CSS3的flex弹性盒模型布局的示例分析
    CSS3的flex弹性盒模型布局的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Flexible Box(弹性盒子)能让页面的分布...
    99+
    2022-10-19
  • css3的弹性盒子模型实例分析
    这篇文章主要介绍了css3的弹性盒子模型实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇css3的弹性盒子模型实例分析文章都会有所收获,下面我们一起来看看吧。   1....
    99+
    2022-10-19
  • CSS使用盒模型的实例介绍
    这篇文章主要讲解了“CSS使用盒模型的实例介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS使用盒模型的实例介绍”吧!1. 为元素应用内边距应用内边距...
    99+
    2022-10-19
  • CSS盒模型BoxModel的用法介绍
    这篇文章主要讲解了“CSS盒模型BoxModel的用法介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS盒模型BoxModel的用法介绍”吧!这里向大...
    99+
    2022-10-19
  • CSS盒模型的算法和应用
    本篇内容介绍了“CSS盒模型的算法和应用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!CSS盒模型网页设计...
    99+
    2022-10-19
  • Tomcat中NIO模型的示例分析
    这篇文章给大家分享的是有关Tomcat中NIO模型的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、I/O复用模型解读Tomcat的NIO是基于I/O复用来实现的。对这点一定要清楚,不然我们的讨论就不在...
    99+
    2023-06-02
  • Flutter 容器盒子模型的使用示例
    目录样例代码在讲 Flutter 的盒子模型前,先看看HTML 中的盒子模型。如下图所示,一个页面元素包括了与父级容器的外边距(margin),自身内容与边框的内边距(padding...
    99+
    2022-11-12
  • CSS盒子隐藏/显示后再最上层的示例分析
    小编给大家分享一下CSS盒子隐藏/显示后再最上层的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!.imgbox{width: 1200px;he...
    99+
    2023-06-08
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作