CSS入门10-替换元素和非替换元素,块级元素和行内元素

CSS入门10-替换元素和非替换元素,块级元素和行内元素,第1张

我们知道html中元素对外表现都是一个个盒子或者说是框,那么这些盒子是否都一样呢?前面说过,这些盒子有的是从上到下竖着摆放的,而有的是横着摆放的。另外,有的盒子装的内容是直接展示的,有的却是魔术盒,根据标签和属性决定具体的展示内容。

替换元素是指,浏览器会根据元素的标签和属性,来决定元素的具体显示内容。 其内容不受CSS视觉格式化模型控制,CSS渲染模型并不考虑对此内容的渲染,且元素本身一般拥有固有尺寸(宽度,高度,宽高比)。

最明显的两个例子:

另外,textarea、select、object、video都是替换元素。这些元素往往没有实际的内容,即是一个空元素,浏览器会根据元素的标签类型和属性来显示这些元素。audio和canvas在某些特定情形下为替换元素。使用CSS的content属性插入的对象是匿名替换元素。

HTML 的大多数元素是非替换元素,浏览器直接将其内容显示出来。例如:div, p, span

普通流中,块元素独占一行。例如:div,p,h1等。

普通流中,行内元素左右可以有其他行内元素。

块级元素,width,height,margin,boder的设置遵循盒模型。

行内替换元素,width,height,margin,boder的设置遵循盒模型。另外,当其宽高有auto属性时,其表现如下:

css 行内元素 块元素 替换元素 非替换元素 以及这些元素的width height margin padding 特性
替换元素和非替换元素
html元素两种分类。替换元素和不可替换元素;块级元素和行内元素
置换元素(替换元素)和非置换元素(不可替换元素)
行内元素与块级元素的总结
置换和非置换元素

其实,想两个链接在一行,你应该去掉的是
in-tad dd a{color:#999;display:block}中的display:block
改为in-tad dd a{color:#999;}即可。
你试试:)
解释:display:block 是使链接a为块级元素,而块级元素的一个特点就是,它们总是在新行上开始,所以,楼主要想达到一行的效果,去掉它就可以了。

其实你这个问题和我很早学这个css的一个问题一样。既然浮动元素脱离了文档流,为什么文字会停在浮动元素的周边而不是跟浮动元素重合呢?

第一,浮动的目的。最初时,浮动只能用于图像(某些浏览器还支持表的浮动),目的就是为了允许其他内容(如文本)“围绕”该图像。而后来的CSS允许浮动任何元素。

  第二,绝对定位与浮动的区别。

  绝对定位是将元素彻底从文档流删除,并相对于其包含块定位(包含块可能是文档中的另一个元素或者是初始包含块),元素原先在正常文档流中所占的空间会关闭,就好像该元素原来不存在一样,该元素再也不会影响其他元素的布局了。如果将元素A定位到左上角的话,元素B占据元素A之前的位置,与元素A重合在一起,并被元素A覆盖。CSS代码和效果图如下。

而浮动,会以某种方式将浮动元素从文档的正常流中删除,并把浮动元素向左边和右边浮动,不过它还是会影响布局,关于浮动的有许多规则,读者可自行阅读《CSS权威指南》一书,介绍地很详细。采用CSS的特有方式,浮动元素几乎“自成一派”,不过它们还是对文档的其余部分有影响。这种影响源自于这样一个事实:一个元素浮动时,其他内容会“环绕”该元素。如果将元素A向左浮动的话,CSS代码和效果图如下图所示。由此可见,浮动之后,文字跑到了元素A的右边,即实现了文字环绕浮动元素的功能(如果A不浮动的话,div是块级元素,不可能有两个div处在同一行)。

以上都是我自己所想,希望可以帮到初学者。如果有错误或者不妥的地方,也请高手指出,我定当改正,谢谢!!

html中的标签有行元素(inline)、块元素(block)、行块元素(inline-block),三种,以下就简单整理一下。(本文只整理常见的,想要完整版的小伙伴可以自行查看手册哦)。

1、常见块元素:div h1 h2 h3 h4 h5 h6 p ul li ol form tr th 。

特点:块元素display:block   独占一行   默认宽度父级宽度的100%,默认垂直显示,可设置宽高、padding、margin。

2、常见行内元素:span  a i br。

特点:行元素display:inline  宽度自适应,靠内容撑开(以内容的大小为大小),水平显示,在一行之内。不能写宽高,可改变display:block不支持垂直方向的margin和padding,但左右方向的margin和padding是可以设置的。

3、常见行块元素:img。

特点:display:inline-block 对外表现为行级,对内表现为块级支持宽高,支持垂直方向的margin和padding。

若想要使行元素块元素之间相互转换可设置display属性。

在css盒子模型中,我们提到了html元素中的块元素(block element)和内联元素(inline element)。那么它们究竟是什么呢?
其实,这两种元素都是html规范中的概念。块元素(block
element)一般是其他元素的容器元素,能容纳其他块元素或内联元素。最常见的就是P和div这两个,说的简单点,块元素就好比一个四方块,可以放其他的四方块,并可以呈现在页面上任何地方。默认情况下块元素,是独占一行的。常见的块元素:div、h1-h6标题、form(只能用来容纳其他块元素)、hr、p、table、ul、ol等。内联元素(inline

element)也叫内嵌元素或行内元素,一般都是基于语义级(semantic)的基本元素。内联元素只能容纳文本或者其他内联元素,常见内联元素有a和span。
块元素与内联元素的区别?
1块元素,总是在新行上开始;内联元素,和其他元素都在一行上。
2块元素,能容纳其他块元素或内联元素;内联元素,只能容纳文本或者其他内联元素。
3块元素中高度,行高以及顶和底边距都可控制;内联元素中高,行高及顶和底边距不可改变。
(这上面的区别,指的是默认情况下的,不包括CSS的刻意控制。也就是说当使用css控制时,块元素和内联元素的属性差异会越来越小。)
block(块)元素的特点:
①总是在新行上开始;
②高度,行高以及外边距和内边距都可控制;
③宽度缺省是它的容器的100%,除非设定一个宽度。
④它可以容纳内联元素和其他块元素
inline元素的特点:
①和其他元素都在一行上;
②高,行高及外边距和内边距不可改变;
③宽度就是它的文字或的宽度,不可改变
④内联元素只能容纳文本或者其他内联元素
CSS文档流与块级元素(block)、内联元素(inline),之前翻阅不少书籍,看过不少文章,
看到所多的是零碎的CSS布局基本知识,比较表面。看过O'Reilly的《CSS权威指南》,发现里面提到的文档流概念让我很敏感。
可恶的是书中并没有解释文档流是什么东西,或许作者觉得这个太简单了以至于不值一提。但我觉得,这个概念实在太重要了。理解了它,一堆CSS布局的理论都变得易于理解,并且体会到CSS这套设计的合理性所在。
文档流
将窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素,即为文档流。
每个非浮动块级元素都独占一行, 浮动元素则按规定浮在行的一端。 若当前行容不下, 则另起新行再浮动。
内联元素也不会独占一行。 几乎所有元素(包括块级,内联和列表元素)均可生成子行, 用于摆放子元素。
有三种情况将使得元素脱离文档流而存在,分别是浮动,绝对定位, 固定定位。 但是在IE中浮动元素也存在于文档流中(还让我觉得这样很合理><)。
浮动元素不占任何正常文档流空间,而浮动元素的定位还是基于正常的文档流,然后从文档流中抽出并尽可能远的移动至左侧或者右侧。文字内容会围绕在浮动元素周围。当一个元素从正常文档流中抽出后,仍然在文档流中的其他元素将忽略该元素并填补他原先的空间。
浮动概念让人迷惑根源在于浏览器对理论的解读造成的。只能说很多人以IE做标准,其实它不是。
基于文档流, 我们可以很容易理解以下的定位模式:
相对定位, 即相对于元素在文档流中位置进行偏移。 但保留原占位。
绝对定位, 即完全脱离文档流, 相对于position属性非static值的最近父级元素进行偏移。
固定定位, 即完全脱离文档流, 相对于视区进行偏移。
几个问题
•作为三大基本元素之一的内联元素。 它跟块级元素的主要区别在哪?
•Clear属性取right值时怎么理解? 貌似实验情况总跟理论不符
•内联元素是什么意思呢?什么是块级别元素?
《CSS权威指南》中文字显示:任何不是块级元素的可见元素都是内联元素。其表现的特性是“行布局”形式,这里的“行布局”的意思就是说其表现形式始终以行进行显示。比如,我们设定一个内联元素border-bottom:1px
solid #000;时其表现是以每行进行重复,每一行下方都会有一条黑色的细线。如果是块级元素那么所显示的的黑线只会在块的下方出现。
p、h1、或div等元素常常称为块级元素,这些元素显示为一块内容;Strong。span等元素称为行内元素,它们的内容显示在行中,即“行内框”。(可以使用display=block将行内元素转换成块元素,display=none表示生成的元素根本没有框,也既不显示元素,不占用文档中的空间)
•行内就是在一行内的元素,只能放在行内;块级元素,就是一个四方块,可以放在页面上任何地方。
•说白了,行内元素就好像一个单词;块级元素就好像一个段落,如果不另加定义的话,它将独立一行出现。
•一般的 块级元素诸如段落<p>、标
题<h1><h2>、列表。<ul><ol><li>
、表格<table>、表单<form>、DIV<div>和BODY<body>等元素。而内联元素则如:
表单元素<input>、超级链接<a>、图像<img>、<span>
•块级无素的显著特点是:每个块级元素都是从一个新行开始显示,而且其后的无素也需另起一行进行显示。
•<span>在CSS定义中属于一个行内元素,而<div>是块级元素。
对于学过CSS的人来说一听就能明白。可对于新手来说不易理解,我主要对新手说通熟点吧!
用容器这一词会更容易形象理解它们的存在与用途,行内元素相当一个小容器,而<div>相当于一个大容器,大容器当然可以放一个小容器了。<span>就是小容器,这样一说你也许会在脑海中有一个初步的印象了吧,如果我们想在大容器中装一些清水。但我也想在里装一些墨水怎么
办?很简单,我们把小容器拿出来装上墨水然后放入大容器里的清水中不就成了吗。
块元素(block element)一般是其他元素的容器元素
块元素一般都从新行开始,它可以容纳内联元素和其他块元素。常见块元素是段落标签'P"。“form"这个块元素比较特殊,它只能用来容纳其他块元素。
如果没有css的作用,块元素会顺序以每次另起一行的方式一直往下排。而有了css以后,我们可以改变这种html的默认布局模式,把块元素摆放到你想要
的位置上去。而不是每次都愚蠢的另起一行。需要指出的是,table标签也是块元素的一种,table based layout和css based

layout从一般使用者(不包括视力障碍者、盲人等)的角度来看这两种布局,除了页面载入速度的差别外,没有其他的差别。但是如果普通使用者不经意点了

查看页面源代码按钮后,两者所表现出来的差异就非常大了。基于良好重构理念设计的css布局页面源码,至少也能让没有web开发经验的普通使用者把内容快速的读懂。从这个角度来说,css
layout code应该有更好的美学体验吧。
你能够把块容器元素div想象成一个个box,或者如果你玩过剪贴文载的话,那就更加容易理解了。我们先把需要的文章从各种报纸、杂志总剪
下来。每块剪下来的内容就是一个block。然后我们把这些纸块按照自己的排版意图,用胶水重新贴到一张空白的新纸上。这样就形成了你自己独特的文摘快报了。作为一种技术的延伸,网页布局设计也遵循了同样的模式。
内联元素(inline element)一般都是基于语义级(semantic)的基本元素。内联元素只能容纳文本或者其他内联元素,常见内联元素 “a”。
块元素(block element)和内联元素(inline
element)都是html规范中的概念。块元素和内联元素的基本差异是块元素一般都从新行开始。而当加入了css控制以后,块元素和内联元素的这种属
性差异就不成为差异了。比如,我们完全可以把内联元素cite加上display:block这样的属性,让他也有每次都从新行开始的属性。
可变元素的基本概念就是他需要根据上下文关系确定该元素是块元素或者内联元素。可变元素还是属于上述两种元素类别,一旦上下文关系确定了他的类别,他就要遵循块元素或者内联元素的规则限制。大致的元素分类见全文。
关于inline
element的中文叫法,有多种内联元素、内嵌元素、行内元素、直进式元素。基本上没有统一的翻译,爱怎么叫怎么叫吧。另外提到内联元素,我们会想到有个display的属性是display:inline;这个属性能够修复著名的IE双倍浮动边界问题。
块元素(block element)
•address - 地址
•blockquote - 块引用
•center - 举中对齐块
•dir - 目录列表
•div - 常用块级容易,也是css layout的主要标签
•dl - 定义列表
•fieldset - form控制组
•form - 交互表单
•h1 - 大标题
•h2 - 副标题
•h3 - 3级标题
•h4 - 4级标题
•h5 - 5级标题
•h6 - 6级标题
•hr - 水平分隔线
•isindex - input prompt
•menu - 菜单列表
•noframes - frames可选内容(对于不支持frame的浏览器显示此区块内容)
•noscript - 可选脚本内容(对于不支持script的浏览器显示此内容)
•ol - 排序列表
•p - 段落
•pre - 格式化文本
•table - 表格
•ul - 非排序列表内联元素(inline element)
•a - 锚点
•abbr - 缩写
•acronym - 首字
•b - 粗体(不推荐)
•bdo - bidi override
•big - 大字体
•br - 换行
•cite - 引用
•code - 计算机代码(在引用源码的时候需要)
•dfn - 定义字段
•em - 强调
•font - 字体设定(不推荐)
•i - 斜体
•img -
•input - 输入框
•kbd - 定义键盘文本
•label - 表格标签
•q - 短引用
•s - 中划线(不推荐)
•samp - 定义范例计算机代码
•select - 项目选择
•small - 小字体文本
•span - 常用内联容器,定义文本内区块
•strike - 中划线
•strong - 粗体强调
•sub - 下标
•sup - 上标
•textarea - 多行文本输入框
•tt - 电传文本
•u - 下划线
•var - 定义变量可变元素
可变元素为根据上下文语境决定该元素为块元素或者内联元素。
•applet - java applet
•button - 按钮
•del - 删除文本
•iframe - inline frame
•ins - 插入的文本
•map - 区块(map)
•object - object对象
•script - 客户端脚本

比如:
div ID为box, 它原有的属性为:
<style type="text/css">
#box {width: 100px; height: 100px; border: 1px solid red;}
</style>
<div id="box">测试数据</div>
要改为行内样式的话,在div 内添加 style=“” 把属性尽数复制到style中就可以了,如下
<div style="width: 100px; height: 100px; border: 1px solid red;">测试数据</div>
这样就不用ID属性去调外部css代码了,所以可省略;
希望你能看懂!!!

你说的是将 行内元素标签 转换成 块级元素标签对吧
打个比如吧 <span></span> 是个行内元素
<span style="display:block"></span>
display:block 意思是块状形式陈列出来,这样span标签就可以控制它的宽和高了


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/13376855.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-24
下一篇 2023-07-24

发表评论

登录后才能评论

评论列表(0条)

保存