CSS页面布局=盒子模型+浮动+定位

一、CSS盒子模型

所谓盒子模型∶就是把 HTML页面中的布局元素看作是一个矩形的盒子,也就是一个盛装内容的容器。

CSS盒子模型本质上是一个盒子,封装周围的HTML元素,它包括∶边框、外边距、内边距、和实际内容

1.网页布局过程︰

1.先准备好相关的网页元素,网页元素基本都是盒子Box

2.利用CSS 设置好盒子样式,然后摆放到相应位置

3.往盒子里面装内容

网页布局的核心本质:就是利用CSS摆盒子

2.盒子模型(Box Model)组成:

边框border:

边框属性简写:(顺序无先后)

练习:请给一个 200*200 的盒子,设置上边框为红色,其余边框为蓝色

表格的细线属性border-collapse:

collapse单词是合并的意思

border-collapse: collapse;    表示相邻边框合并在一起

圆角边框border-radius:

在CSS3中,新增了圆角边框样式,这样我们的盒子就可以变圆角了。

将边框变为圆框
使用百分比来指定 border-radius 的值

盒子阴影box-shadow:

CSS3中新增了盒子阴影,我们可以使用box-shadow属性为盒子添加阴影。

注意:

1.默认的是外阴影(outset),但是不可以写这个单词,否则造成阴影无效

2.盒子阴影不占用空间,不会影响其他盒子排列。

文字阴影text-shadow:

在CSS3中,我们可以使用text-shadow属性将阴影应用于文本。

边距:

内边距padding 用来控制着元素内容与 border之间的空隙大小(px值越大边框宽度/高度越大)。

外边距margin用来控制元素的边框与其他元素之间的 border 距离(px值越大边框长度越小)。如果你把元素的 margin 设置为负值,元素会变得占用更多空间。

如果不想每次都要分别声明 padding-top、padding-right、padding-bottom、padding-left 属性,可以把它们汇总在一行里面一并声明,像是这样:padding:10px 20px 10px 20px;这四个值按顺时针排序:上、右、下、左,并且设置的效果等同于分别声明每一个方向的内边距。(外边距margin相同)

padding与margin一致


二、浮动

1.传统网页布局的三种方式

网页布局的本质——用CSS来摆放盒子。把盒子摆放到相应位置

CSS提供了三种传统布局方式(简单说,就是盒子如何进行排列顺序):

*普通流(标准流)

*浮动

*定位

1.1标准流(普通流/文档流)

所谓的标准流:就是标签按照规定好默认方式排列. 

1.块级元素会独占一行,从上向下顺序排列。 

常用元素:div、hr、p、h1~h6、ul、ol、dl、form、table 

2.行内元素会按照顺序,从左到右顺序排列,碰到父元素边缘则自动换行。

常用元素: span、 a、 i、em等

以上都是标准流布局,我们前面学习的就是标准流,标准流是最基本的布局方式。 

这三种布局方式都是用来摆放盒子的,盒子摆放到合适位置,布局自然就完成了。 

注意∶实际开发中,一个页面基本都包含了这三种布局方式(后面移动端学习新的布局方式)。

1.2为什么需要浮动

如何让多个块级盒子(div)水平排列成一行?

如何去掉行内块元素之间的缝隙呢?

总结︰有很多的布局效果,标准流没有办法完成,此时就可以利用浮动完成布局。因为浮动可以改变元素标签默认的排列方式.

浮动最典型的应用:可以让多个块级元素一行内排列显示且之间没有缝隙。

网页布局第一准则∶多个块级元素纵向排列找标准流,多个块级元素横向排列找浮动。

1.3什么是浮动

float属性用于创建浮动框,将其移动到一边,直到左边缘或右边缘触及包含块或另一个浮动框的边缘。

1.4浮动特性

1.浮动元素会脱离标准流(脱标),浮动的盒子不再保留原先的位置

2.浮动的元素会一行内显示并且元素顶部对齐

注意∶浮动的元素是互相贴靠在一起的(不会有缝隙),如果父级宽度装不下这些浮动的盒子,多出的盒子会另起一行对齐。

3.浮动的元素会具有行内块元素的特性

*任何元素都可以浮动。不管原先是什么模式的元素,添加浮动之后具有行内块元素相似的特性。

*如果块级盒子没有设置宽度,默认宽度和父级一样宽,但是添加浮动后,它的大小根据内容来决定浮动的盒子中间是没有缝隙的,是紧挨着一起的

1.5浮动元素经常和标准流父级搭配使用

为了约束浮动元素位置,我们网页布局一般采取的策略是:

先用标准流的父元素排列上下位置,之后内部子元素采取浮动排列左右位置.符合网页布局第一准侧.

二、常见网页布局

浮动布局注意点:

1.浮动和标准流的父盒子搭配

先用标准流的父元素排列上下位置,之后内部子元素采取浮动排列左右位置

2.一个元素浮动了,理论上其余的兄弟元素也要浮动

一个盒子里面有多个子盒子,如果其中一个盒子浮动了,那么其他兄弟也应该浮动,以防止引起问题。

浮动的盒子只会影响浮动盒子后面的标准流,不会影响前面的标准流.

三、清除浮动

1.为什么需要清除浮动

由于父级盒子很多情况下,不方便给高度

子盒子浮动又不占有位置,最后父级盒子高度为0时,就会影响下面的标准流盒子。

由于浮动元素不再占用原文档流的位置,所以它会对后面的元素排版产生影响

2.清除浮动本质

*清除浮动的本质是清除浮动元素脱离标准流造成的影响

*如果父盒子本身有高度,则不需要清除浮动

*清除浮动之后,父级就会根据浮动的子盒子自动检测高度。父级有了高度,就不会影响下面的标准流了

3.清除浮动

实际工作中,几乎只用   clear: both

清除浮动的策略是:闭合浮动,只让浮动在父盒子内部影响,不影响父盒子外面的其他盒子

清除浮动的方法:

1.额外标签法:也称为隔墙法,是W3C推荐的做法。在浮动元素末尾添加一个空的标签。例如

2.父级添加overflow属性:可以给父级添加overflow属性,将其属性值设置为hidden、auto或scroll 。子不教父之过,注意是给父元素添加代码

优点︰代码简洁

缺点∶无法显示溢出的部分

3.父级添加  :after   伪元素::after方式是额外标签法的升级版。也是给父元素添加

优点:没有增加标签,结构更简单

缺点︰照顾低版本浏览器

代表网站︰百度、淘宝网、网易等

4.父级添加双伪元素

优点:代码更简洁

缺点:照顾低版本浏览器

代表网站:小米、腾讯等

四、PS切图

1.常见图片格式

1. jpg图像格式︰JPEG ( JPG )对色彩的信息保留较好,高清,颜色较多,我们产品类的图片经常用jpg格式的

2. gif图像格式∶GIF格式最多只能储存256色,所以通常用来显示简单图形及字体,但是可以保存透明背景和动画效果,实际经常用于一些图片小动画效果.

3. png图像格式:是一种新兴的网络图形格式,结合了GIF和JPEG的优点,具有存储形式丰富的特点,能够保持透明背景.如果想要切成背景透明的图片,请选择png格式.

4.PSD图像格式:PSD格式是Photoshop的专用格式,里面可以存放图层、通道、遮罩等多种设计稿.对前端人员来说,最大的优点是可以直接从上面复制文字,获得图片,还可以测量大小和距离.

2.PS切图方式

PS有很多的切图方式∶图层切图、切片切图、PS插件切图等。

图层切图:

最简单的切图方式:右击图层→快速导出为PNG。

但是很多情况下,我们需要合并图层再导出:

1.选中需要的图层:图层菜单→合并图层(ctrl+e)

2.右击→快速导出为PNG

最好的方法是:沟通

切片切图:

1.利用切片选中图片 

利用切片工具手动划出

2.导出选中的图片 

文件菜单→导出→存储为web设备所用格式→选择我们要的图片格式→存储。

PS插件切图:

Cutterman是一款运行在Photoshop中的插件,能够自动将你需要的图层进行输出,以替代传统的手工"导出 web所用格式"以及使用切片工具进行挨个切图的繁琐流程。

五、案例

1.CSS属性书写顺序(重点)

建议遵循以下顺序︰

1.布局定位属性: display / position / float / clear / visibility / overflow   (建议 display第一个写,毕竟关系到模式)

2.自身属性: width / height / margin / padding / border / background

3.文本属性︰color / font / text-decoration / text-align / vertical-align / white- space / break-word

4.其他属性(CSS3 ) : content / cursor / border-radius / box-shadow / text-shadow / background:linear-gradient ...

2.页面布局整体思路

为了提高网页制作的效率,布局时通常有以下的整体思路︰

1.必须确定页面的版心(可视区),我们测量可得知。

2.分析页面中的行模块,以及每个行模块中的列模块。其实页面布局第一准则.

3.一行中的列模块经常浮动布局,先确定每个列的大小之后确定列的位置.页面布局第二准则

4.制作 HTML结构。我们还是遵循,先有结构,后有样式的原则。结构永远最重要.

5.所以,先理清楚布局结构,再写代码尤为重要.这需要我们多写多积累.


CSS之定位   2022/4/3


一、定位position

1.浮动可以让多个块级盒子一行没有缝隙排列显示,经常用于横向排列盒子。

2.定位则是可以让盒子自由的在某个盒子内移动位置或者固定屏幕中某个位置,并且可以压住其他盒子。

1.定位组成:定位=定位模式+边偏移

定位∶将盒子定在某一个位置,所以定位也是在摆放盒子,按照定位的方式移动盒子。

定位模式用于指定一个元素在文档中的定位方式。边偏移则决定了该元素的最终位置。

定位模式:

边偏移:

2.静态定位static(了解)

静态定位是元素的默认定位方式,无定位的意思。

语法︰  选择器{ position : static; }

*静态定位按照标准流特性摆放位置,它没有边偏移

*静态定位在布局时很少用到

3.相对定位relative(重要)

相对定位是元素在移动位置的时候,是相对于它原来的位置来说的(自恋型)。

语法︰选择器 { position : relative; }

pink的box1从(0,0)进行相对偏移

相对定位的特点:(务必记住)

1.它是相对于自己原来的位置来移动的(移动位置的时候参照点是自己原来的位置)。

2.原来在标准流的位置继续占有,后面的盒子仍然以标准流的方式对待它。

因此,相对定位并没有脱标。它最典型的应用是给绝对定位当爹的。。。

4.绝对定位absolute(重要)

绝对定位是元素在移动位置的时候,是相对于它祖先元素来说的(拼爹型)。

语法︰选择器{ position: absolute; }

绝对定位的特点∶(务必记住)

1.如果没有祖先元素或者祖先元素没有定位,则以浏览器为准定位(Document 文档)。

2.如果祖先元素有定位(相对、绝对、固定定位),则以最近一级的有定位祖先元素为参考点移动位置。

3.绝对定位不再占有原先的位置。(脱标)

所以绝对定位是脱离标准流的。

5.子绝父相:子级是绝对定位的话,父级要用相对定位

1.子级绝对定位,不会占有位置,可以放到父盒子里面的任何一个地方,不会影响其他的兄弟盒子。

2.父盒子需要加定位限制子盒子在父盒子内显示。

3.父盒子布局时,需要占有位置,因此父亲只能是相对定位。

这就是子绝父相的由来,所以相对定位经常用来作为绝对定位的父级。

总结︰因为父级需要占有位置,因此是相对定位,子盒子不需要占有位置,则是绝对定位当然,子绝父相不是永远不变的,如果父元素不需要占有位置,子绝父绝也会遇到。

6.固定定位fixed(重要)

固定定位是元素固定于浏览器可视区的位置。主要使用场景∶可以在浏览器页面滚动时元素的位置不会改变。

固定定位的特点∶(务必记住)

1.以浏览器的可视窗口为参照点移动元素:

*跟父元素没有任何关系

*不随滚动条滚动。

2固定定位不在占有原先的位置。

固定定位也是脱标的,其实固定定位也可以看做是─种特殊的绝对定位。

固定定位小技巧:固定在版心右侧位置

1.让固定定位的盒子left: 50%、走到浏览器可视区(也可以看做版心)的一半位置。

2.让固定定位的盒子margin-left:版心宽度的一半距离。多走版心宽度的一半位置

就可以让固定定位的盒子贴着版心右侧对齐了。

7.粘性定位sticky

粘性定位可以被认为是相对定位和固定定位的混合

top为0表示当页面向下滚动时导航栏距离top为0px,即紧贴导航栏

粘性定位的特点︰

1.以浏览器的可视窗口为参照点移动元素(固定定位特点)

2.粘性定位占有原先的位置(相对定位特点)

3.必须添加 top、 left、right、bottom其中一个才有效

跟页面滚动搭配使用。兼容性较差,IE不支持。

9.定位叠放次序

在使用定位布局时,可能会出现盒子重叠的情况。此时,可以使用z-index 来控制盒子的前后次序(z轴)

若未定义叠放次序,则按声明的先后顺序堆放:

*数值可以是正整数、负整数或0,默认是auto,数值越大,盒子越靠上

*如果属性值相同,则按照书写顺序,后来居上

*数字后面不能加单位

*只有定位的盒子才有z-index属性

10.定位的拓展

1.绝对定位的盒子居中

加了绝对定位的盒子不能通过margin:0 auto水平居中,但是可以通过以下计算方法实现水平和垂直居中。

left: 50%;:让盒子的左侧移动到父级元素的水平中心位置。

margin-left: -100px; :让盒子向左移动自身宽度的一半。

⒉定位特殊特性

绝对定位和固定定位也和浮动类似。

1.行内元素添加绝对或者固定定位,可以直接设置高度和宽度。

未添加绝对定位前:宽度和高度不起作用

添加绝对定位后:宽度和高度正常显示

2.块级元素添加绝对或者固定定位,如果不给宽度或者高度,默认大小是内容的大小。

未添加绝对定位前:div的背景绿色显示了一行

添加绝对定位后:div的背景绿色大小与内容大小一致

3.脱标的盒子不会触发外边距塌陷

浮动元素、绝对定位(固定定位)元素的都不会触发外边距合并的问题。

4.绝对定位(固定定位)会完全压住盒子

浮动元素不同,只会压住它下面标准流的盒子,但是不会压住下面标准流盒子里面的文字(图片)

但是绝对定位(固定定位)会压住下面标准流所有的内容:

浮动之所以不会压住文字,因为浮动产生的目的最初是为了做文字环绕效果的。文字会围绕浮动元素

二、网页布局总结

通过盒子模型,清楚知道大部分html标签是一个盒子。

通过CSS浮动、定位可以让每个盒子排列成为网页。

一个完整的网页,是标准流、浮动、定位一起完成布局的,每个都有自己的专门用法。

1.标准流

可以让盒子上下排列或者左右排列,垂直的块级盒子显示就用标准流布局。

2.浮动

可以让多个块级元素一行显示或者左右对齐盒子,多个块级盒子水平显示就用浮动布局。

3.定位

定位最大的特点是有层叠的概念,就是可以让多个盒子前后叠压来显示。如果元素自由在某个盒子内移动就用定位布局。

三、元素的显示与隐藏

类似网站广告,当我们点击关闭就不见了,但是我们重新刷新页面,会重新出现!

本质:让一个元素在页面中隐藏或者显示出来。

1. display显示隐藏

display 属性用于设置一个元素应如何显示。

display: none ;隐藏对象,并且释放该元素的占有位置

display : block ;除了转换为块级元素之外,同时还有显示元素的意思。display隐藏元素后,不再占有原来的位置。

后面应用及其广泛,搭配JS可以做很多的网页特效。

2. visibility 显示隐藏

visibility属性用于指定一个元素应可见还是隐藏。

visibility : visible;元素可视

visibility : hidden;元素隐藏

visibility隐藏元素后,继续占有原来的位置。

如果隐藏元素想要原来位置,就用visibility : hidden

如果隐藏元素不想要原来位置,就用display : none 

3. overflow溢出显示隐藏

overflow属性指定了如果内容溢出一个元素的框(超过其指定高度及宽度)时,会发生什么。

一般情况下,我们都不想让溢出的内容显示出来,因为溢出的部分会影响布局。

overflow: hidden;

overflow: scroll;

overflow: auto; 未超出则不显示滚动条

但是如果有定位的盒子,请慎用overflow:hidden因为它会隐藏多余的部分。

案例

你可能感兴趣的:(CSS页面布局=盒子模型+浮动+定位)