行内元素和块级元素的学习 |
您所在的位置:网站首页 › 行内元素与块元素 › 行内元素和块级元素的学习 |
行内元素和块级元素的学习
@(css)[妙瞳] css标准文档流: 简称"标准流",指的是在不使用其它的与排列和定位相关的特殊CSS规则时,各种元素的排列规则。HTML文档中元素可以分为块级元素和行内元素。 块级元素:总是以一个块的形式表现出来,并且跟同级的兄弟一次竖直排列,左右撑满。 行内元素:行内元素不占据单独的空间,依附于块级元素,行内元素没有自己的区域。它同样是DOM树的一个节点,在这点上,行内元素和块级元素是没有区别的。行内元素不可以设置宽与高,但可以与其他行内元素位于同一行,行内元素内一般不可以包含块级元素。行内元素的高度一般由元素内部的字体大小决定,宽度由内容的长度控制。常见的行内元素有a,em,strong等。 盒子在标准流中的定位原则(见我上篇文章:聊聊盒子模型) (1)行内元素之间的水平margin 当两个行内元素紧邻时,它们之间的距离为第1个元素的margin-right加上第2个元素的margin-left。 (2)块级元素之间的竖直margin 当两个块级元素紧邻时,它们的距离不是margin-bottom与margin-top的总和,而是两者中的较大者。 (3)嵌套盒子之间的margin 当一个div块包含在另一个div块中时,便形成了典型的父子关系。其中子块的margin将以父块的 content为参考。 (4)将margin设置为负值 当margin设置为负值时,会使被设为负数的块向相反的方向移动,甚至覆盖在另外的块上。 代码演示如下: CSS ul{ border:1px solid red; } li{ border:1px solid green; } strong{ border:1px solid #000; } 第1个列表的第1个项目内容 第1个列表的第2个项目内容,内容更长一些, 目的是演示自动折行的效果。 第2个列表的第1个项目内容 第2个列表的第2个项目内容,内容更长一些,目的是演示自动折行 的效果。页面效果: 行内元素的特点: 和其他行内元素都在一行上; 设置宽度width无效,宽度是根据它的内容而定。 设置高度height无效,可以通过line-height来设置。高度随字体大小而变。 设置margin只有左右margin有效,上下无效。 设置padding只有左右padding有效,上下无效。 行内元素只能容纳文本或者其他的行内元素。块级元素的特点: 总是在新行上开始; 高度、行高以及外边距和内边距都可控制; 宽度缺省是它容器的100%,除非设定一个宽度; 它可以容纳行内元素和其他块级元素;假如我对strong的line-height进行设置,效果如下: strong{ border:1px solid #000; line-height:50px; }页面效果:
假如我们对strong的height进行设置,效果如下: strong{ border:1px solid #000; height:50px; }页面效果:
代码: li{ border:1px solid green; margin-left:20px; margin-right:20px; margin-top:20px; margin-bottom:20px; } strong{ border:1px solid #000; margin-left:20px; margin-right:20px; margin-top:20px; margin-bottom:20px; }页面效果图: 由上可示,对于行内元素strong而言,margin-left和margin-right有效,但是margin-top和margin-bottom失效。对于块级元素li而言,上下左右的margin都有效。 代码: li{ border:1px solid green; padding-left:20px; padding-right:20px; padding-top:20px; padding-bottom:20px; } strong{ border:1px solid #000; padding-left:20px; padding-right:20px; padding-top:30px; padding-bottom:20px; }页面图:
行内元素和块级元素的区别: 行内元素会在一条直线上排列,都是同一行的,水平方向排列, 块级元素各占据一行,垂直方向排列。块级元素从新行开始结束接着一个断行。 块级元素可以包含行内元素和块级元素。行内元素不能包含块级元素。 行内元素与块级元素属性的不同,主要是盒模型属性上 行内元素设置width无效,height无效(可以设置line-height),margin上下无效,padding上下无效,而块级元素都有效。 text-align属性是两者表现的又以不同之处 在W3C CSS2.1规范第16.2节 对text-align 有详细地描述: 值: left | right | center | justify | inherit初始值:匿名值,由'direction'的值而定,如果'direction'为'ltr'则为'left',如果'direction'为'rtl'则为'right'。 应用于: 块级元素,表格单元格,行内块元素 继承性: 是 计算后的值:初始值或指定值 这个特性描述了如何使一个块元素的行内内容对齐。 注意一点,标准里说这个属性是用来对齐行内内容的,所以,不应该对块级内容起作用。 解释一下,行内内容是说由行内元素组成的内容,比如 SPAN 元素,IFRAME元素和元素样式的 ‘display : inline’ 的都是行内元素;块级内容跟则是由块级元素构成,DIV 是最常用的块级元素。块级元素和行内元素的区别是,块级元素会占一行显示,而行内元素可以在一行并排显示。 这样,我们对这个特性的认识应该就清楚了。但是,虽然标准里这么规定,那么是不是所有浏览器都遵守呢?答案是否定的。 IE6/7及IE8混杂模式中,text- align:center可以使块级元素也居中对齐。其他浏览器中,text-align:center仅作用于行内内容上。 解决上面的问题比较好的方式,就是为所有需要相对父容器居中对齐的块级元素设置“margin-left:auto; margin-right:auto”。但这个方式 IE6/IE7/IE8的混杂模式中不支持,所以还要设置父容器的 "text-align:center;"。若居中对齐的子元素内的行内内容不需要居中对齐,则还需要为其设置“text-align:left”。 代码: CSS body{ width:800px; border:1px solid #000; } div.wrapper{ /*margin:0 auto;*/ width:500px; border:1px solid red; text-align: center; } div.box1{ border:1px solid red; } div strong{ border:1px solid green; } 我是行内元素我是块级元素 页面: IE8/Firefox/Chrome/Safari/Opera: IE6/IE7:
代码: CSS body{ width:800px; border:1px solid #000; } div.wrapper{ margin:0 auto; width:500px; border:1px solid red; } div.box1{ border:1px solid red; text-align:center; } div strong{ border:1px solid green; } 我是行内元素我是块级元素 IE8/Firefox/Chrome/Safari/Opera: IE6/IE7: 代码: CSS body{ width:800px; border:1px solid #000; } div.wrapper{ margin:0 auto; width:500px; border:1px solid red; text-align:center; } div.box1{ border:1px solid red; } div strong{ border:1px solid green; } 我是行内元素我是块级元素 IE6/IE7/IE8/Firefox/Chrome/Safari/Opera: 块级元素、行内元素分别汇总如下: Examples of block level elements block level elements|Element Description information on author long quotation push button table caption definition description deleted text generic language/style container definition list definition term form control group interactive form heading heading heading heading heading heading horizontal rule inline subwindow inserted text fieldset legend list item client-side image map alternate content container for non frame-based rendering alternate content container for non script-based rendering generic embedded object ordered listparagraph preformatted text table table body table data cell table footer table header cell table header table row unordered list Examples of inline elements inline elements | Element Description anchor abbreviated form acronym bold text style I18N BiDi over-ride large text style forced line break push button citation computer code fragment deleted text instance definition emphasis italic text style inline subwindow块级元素列表 定义地址 定义表格标题 定义列表中定义条目 定义文档中的分区或节 定义列表 定义列表中的项目 定义一个框架集 创建 HTML 表单 定义最大的标题 定义副标题 定义标题 定义标题 定义标题 定义最小的标题 创建一条水平线 元素为 fieldset 元素定义标题 标签定义列表项目 为那些不支持框架的浏览器显示文本,于 frameset 元素内部 定义在脚本未被执行时的替代内容 定义有序列表 定义无序列表标签定义段落 定义预格式化的文本 标签定义 HTML 表格 标签表格主体(正文) 表格中的标准单元格 定义表格的页脚(脚注或表注) 定义表头单元格 标签定义表格的表头 定义表格中的行 行内元素列表 标签可定义锚 表示一个缩写形式 定义只取首字母缩写 字体加粗 可覆盖默认的文本方向 大号字体加粗 换行 引用进行定义 定义计算机代码文本 定义一个定义项目 定义为强调的内容 斜体文本效果可变元素素列表--可变元素为根据上下文语境决定该元素为块级元素或者内联元素 按钮 定义文档中已被删除的文本 创建包含另外一个文档的内联框架(即行内框架) 标签定义已经被插入文档中的文本 客户端图像映射(即热区) object对象 客户端脚本行内元素转换为块级元素 display:block; (字面意思表现形式设为块级) display:inline; display:inline-block;可以通过修改样式display属性改变元素是以块级还是行内元素呈现,当display的值设为block时,元素将以块级方式呈现;当display值设为inline时,元素将以行内形式呈现。 如果想让一个元素可以设置宽度高度,又让它以行内形式显示,我们可以设置display的值为inline-block。 通过css设定了浮动(float属性,可向左浮动或向右浮动)以及设定显示(display)属性为“block”或“list-item”的元素都是块级元素。 但是浮动元素比较特殊,由于浮动,其旁边可能会有其他元素的存在。而“list-item”(列表项 ),会在其前面生成圆点符号,或者数字序号。假如有不足或者错误的地方,欢迎指正哟。-------妙瞳 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |