首页 > 如何用CSS快速布局(一)—— 布局元素详细

如何用CSS快速布局(一)—— 布局元素详细

要快速进行网页排版布局,则必须对布局的元素有清晰的了解,才不会总是在细节处出错。这一篇先详解有关布局的因素作为布局基础:块级元素and内联元素、盒模型、准确定位、元素对齐、样式继承。下一篇则重点描述快速布局思路。

一、什么是块级元素和内联元素

1,块级元素:

display:block表现出来的特点是折行的, 一般来说可以包含块级元素和内联元素;
例外:
P 元素,只能包含内联元素,而不能包含块级元素。
"form"这个块元素比较特殊,它只能用来容纳其他块元素。

2,内联元素:

display:inline表现出来是不换行的,内部只能包含内联元素。
像“span”这样的行内元素,没有自己的独立空间,它是依附于其他块级元素存在的,因此,对行内元素设置高度、宽度、内外边距等属性,都是无效的。 其实你需要知道的行内元素就是 span 和 a 

3,浮动元素自动设置为"block"元素

不管是block还是inline定义了浮动之后,可以定义高度,宽度.
如果加上float:left的话,能定义高宽,整块对鼠标有反应 但是 它是横向菜单,
设置display:inline;这个属性能够修复著名的IE双倍浮动边界问题。↓(貌似这个问题只存在于IE6?)
http://www.zzzszy.com/a/2016/0927/896160.html
块元素(block element)内联元素(inline 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 - 非排序列表
* 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 - 定义变量

4,可变元素

可变元素为根据上下文语境决定该元素为块元素或者内联元素。
* applet - java applet
* button - 按钮
* del - 删除文本
* iframe - inline frame
* ins - 插入的文本
* map - 图片区块(map)
* object - object对象
* script - 客户端脚本

5,display:inline-block;

维持块级元素可设置宽高,但又能像内联元素一样和其他内联元素置于一行。

 

二、盒模型

 

 

三、如何定位——相对定位、绝对定位、浮动

相对定位:指相对于文档流中的其他已定义的元素位置进行定位。

static(默认值):如果使用默认值,在CSS中为元素定义的top,left,right,bottom.z-index都不会生效。
relative:相对元素本身进行移动。

绝对定位:会脱离正常的文档流,不再占据空间。

absolute:相对一个不为static的父元素进行绝对定位,如果不指定父元素的position,absolute将相对整个html文档进行绝对定位。会优先显示于正常文档流定位元素以及float元素。
fixed:相对浏览器窗口进行定位,不论网页如何滚动,该元素始终停留在屏幕的某个位置上。

浮动:float

脱离文档流——相对父元素大小调整位置。如果父元素宽度为100,两个子元素宽度分别为200,则依旧显示为上下层次,而不是左右。
外盒子——会优先显示于正常文档流定位元素。内盒子——弱于块级元素,强于内联元素

 

重点!定位元素与文档流显示关系

1,正常文档流之间的内外部盒子显示关系:

复制代码
代码结构如下(粗略展示)
黄色块正方形
红色块
红色块
蓝色块正方形
复制代码
黄色和蓝色为外部文档流,红色的为黄色块的两个内部文档流。
外部盒子为外部文档流,内部盒子有自己的文档流,互不干扰,但(非自身父元素的)外部文档流会优先显示于内部文档流。

 

2,内部盒子浮动元素和内部文档流元素关系:

然而当设置为浮动元素后,文档流内联元素让位于浮动元素(先后于
定义结果一样)。如下:
还会出现文字包绕现象:
  •  块级元素和浮动元素优先级
当块级元素先于浮动元素定义时,浮动元素换行排后。当浮动元素先定义时,脱离文档流,不对正常文档流的块级元素造成影响。

3,内部盒子浮动元素和外部文档流内部元素关系:

浮动元素覆盖外部文档流元素,但不占据空间。
绿色块和图片是蓝色块的内部元素,可见,块级元素照正常文档流显示,但内联元素img还是会让步于浮动元素,即使是外部文档流的浮动元素。

 

4,兄弟元素绝对定位和浮动的优先关系

蓝色块为黄色内部块的absolute定位元素,且先于红色块设置div。红色块为Float定位元素,被absolute覆盖。

5,绝对定位和文档流元素的优先关系&相对定位元素的优先关系

绝对定位position:absolute。
1,相对一个不为static的父元素进行绝对定位,如果不指定父元素的position,absolute将相对整个html文档进行绝对定位。
2,如果没有设置topleftottom ight,则其顶端和左侧将与原文档流位置一致(即跟没有设置position一样),但又会覆盖掉外部文档流内部浮动元素多出部分。
下图为蓝色块设置position:absolute;
(注:黄色块(内含红色和绿色子元素)和蓝色块(内含绿色子元素)是兄弟元素)
调换下顺序,蓝色块首先设置div,position为absolute。黄色块没设置position,即默认static。因为脱离了文档流,absolute元素优先显示。
设置黄色块position为relative,黄色块覆盖绝对定位元素。即当相对定位元素后于绝对定位元素定位时,相对定位元素优先显示。

 

总结:

1,正常文档流下,外部盒子优先显示于先定义元素的内盒子(如果超出会被覆盖)。块级元素和内联元素不会在同一行。

    

2,对内外部文档流,浮动元素脱离文档流,对于先定义的元素按正常文档流显示(让位块级,挤开内联),对后定义的元素不造成布局影响,但却影响正常文档流的内联元素展示,表现为内联元素依旧会被浮动元素“挤开”(不论哪里的内联元素,都不会被覆盖在浮动元素之下)

    

3,绝对定位元素优先显示于浮动元素。

    

4,不设置具体值的绝对定位元素会按正常文档流排列,但脱离文档流,不对后定义元素造成影响。

    

5,如果兄弟元素设置了position:relative;当先于绝对定位元素定义时,绝对定位元素优先显示于相对定位元素。

当后于绝对定位元素定义时,相对定位元素优先显示于绝对定位元素。

     

 

四、如何居中对齐

 水平居中:

1.实现行内元素的居中。方法:在行内元素外面的块元素的样式中添加:text-align:center;

2.实现块级元素的水平居中。

  方法一:margin:0 auto;

 注意:如果块级元素是body的直接子元素,不设置宽,则默认100%,看不出效果;不设置高,且div中没有内容,则高度默认为0。因此,一定要同时设置块级元素的宽和高,这样才能看出来效果。对于在一个div中的另一个div希望居中,也可以使用这个方式,因为这时的margin是相对于其父元素而言的。

  

  方法二:使用绝对定位和负边距。

    position:absolute;

    left:50%;                 ——相对于父元素向左移动50%宽度

    margin-left:-50px;    ——移回自身宽度的一半

 

垂直居中

1.行内元素的垂直居中

  方法一:让字体垂直居中,line-height设置为父元素高度。

  方法二:设置padding让其垂直居中。

    方法三:父元素设置line-height,行内元素设置vertical-align:middle。

 

2.块级元素的垂直居中。

   方法一:使用绝对定位和负边距。

   方法二:在父元素中添加display:flex;align-items:center;即可实现竖直居中。

 

实现水平和垂直居中

  方法一:使用绝对定位和负边距

  方法二:使用display:flex

      在父元素的样式中添加display:flex;align-items:center实现竖直居中,justify-content:center;实现水平居中

  方法三:同样使用display:flex.在父元素中设置display:flex;在子元素中设置margin:auto。

  方法四:使用css3属性——translate()变形函数

      position: absolute; top:50%; left:50%; transform:translate(-50%,-50%);

参考文章:css居中那点事儿

 

 

五、关于样式继承

盒模型样式是不可继承的,例如width、height(宽高)、border(边框)、margin(边距)、padding(补白)和背景等
vertical-align不可继承
可继承属性
color  
cursor  
direction  
font  
letter-spacing  
line-height  
list-style  
text-align  
text-indent  
text-shadow  
text-transform  
whitewhite-space  
word-break   
word-spacing  
word-wrap   
writing-mode  

 》转载

转载于:https://www.cnblogs.com/wenJiaQi/p/6329632.html

更多相关:

  • 栈stack:stack 后入先出(LIFO) q.top()获取栈顶元素(并不删除)q.pop()删除栈顶元素q.push(x)向栈中加入元素q.empty()判断栈是否为空 队列queue:先入先出(FIFO)   q.front()获取队首元素(并不删除)q.pop()删除队首元素q.push(x)向队列中加入元素q....

  • resize(),设置大小(size); reserve(),设置容量(capacity); size()是分配容器的内存大小,而capacity()只是设置容器容量大小,但并没有真正分配内存。 打个比方:正在建造的一辆公交车,车里面可以设置40个座椅(reserve(40);),这是它的容量,但并不是说它里面就有了40个座椅,只能说...

  • v-for="(index,$i) in total" :key="$i":style="{left:`${itemWidth*((index-1)%rowItemCount)}px`,top:`${itemHeight*(Math.ceil(index/rowItemCount)-1)}px`}" //total是显示总数量 //l...

  •   技巧一(推荐指数★★★★★) 采用top、right、bottom、left,可以不在乎父元素的宽度和高度,对GPU损耗低于技巧三,但是对浏览器内存的消耗高于技巧三 .子元素 {/*父元素需要position: relative|absolute;*/position: absolute;margin: auto;to...

  • 设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈。 push(x) – 将元素 x 推入栈中。pop() – 删除栈顶的元素。top() – 获取栈顶元素。getMin() – 检索栈中的最小元素。 示例: MinStack minStack = new MinStack(); minStack...

  • 标题:Compact 3D Map-Based Monocular Localization Using Semantic  Edge Alignment作者:Kejie Qiu, Shenzhou Chen, Jiahui Zhang, Rui Huang, Le Cui, Siyu Zhu, and Ping Tan排版:点云P...

  • Android常用的三种定位方式有:基于GPS定位、基于基站地位、基于wifi定位。   1、基于GPS定位:  GPS定位需要GPS模块(硬件)的支持,没有GPS模块是无法进行GPS定位的。  GPS定位最大的优点就是其定位精确度高(一般误差在10m内),无网络也能用;缺点就是耗电高、定位慢、室内和地下室基本定位不到。   2、基于...

  • 参考文档...

  • 有好几天没有更新博客了,前段时间因为要开学了,需要凑足学费才能继续在学校学习,耽误了几天,这两天需要补充前面需要学习的一些知识点了。今天就开始进入JavaWeb阶段吧,这段时间我们需要了解一些前端的知识,还有数据库方面的等等,具体的我下次回顾的时候再谈,今天就开始XML方面的一些基础知识的回顾吧!!   一. xml概述 1.1.xm...

  • zeal是一个windows上的开源的离线文档浏览工具,基于docset格式,可以兼容全部dash的文档。zeal没有代码片段管理的功能,只提供文档浏览功能,不过windows下的用户可算是有的用了。dash目前只提供mac上的版本,作者说有往windows上移植的打算,但迟迟没有动工。 刚安装好之后是没有文档可以看的, 需要自己下...

  • 2019独角兽企业重金招聘Python工程师标准>>> 王超:奇虎360MongoDB     MongoDB是高性能开源文档数据库,也是目前最受关注的NoSQL技术之一,以敏捷、可扩展和对企业应用友好(支持事务,一致性和数据完整性保证。该文档具体讲到了奇虎360为什么会使用MongoDB?MonoDB在亿级数据规模...

  •    本来不打算写这个博客的,我讨厌的话题,但是现实中遇到很多事情让我觉得是我沟通有问题!沟通是两个人的事情,做技术的人你和别人沟通需要看对方是什么水平的人,啥也不懂,啥也不会的人,你用那么专业的术语来描述,肯定解决不了问题。最好是举一些通俗易懂的例子    作为一个新人,我们应该在遇到问题的时候,先自己尝试去了解一些东西,比如:一...