zoukankan      html  css  js  c++  java
  • css进阶 02-CSS布局

    02-CSS布局

    #前言

    #常见的布局属性

    (1)display 确定元素的显示类型:

    • block:块级元素。

    • inline:行内元素。

    • inline-block:对外的表现是行内元素(不会独占一行),对内的表现是块级元素(可以设置宽高)。

    (2)positon 确定元素的位置:

    • static:默认属性值。

    • relative:相对定位。相对于元素本身进行偏移,不会改变它所占据的空间。

    • absolute:绝对定位。相对于父元素中最近的 relative/absolute 进行偏移,会脱离文档流。音标:[ˈæbsəluːt]。

    • fixed:固定定位。相对于可视区域固定,会脱离文档流。

    relativeabsolutefixed这三个属性,可以结合 z-index 来设置层级。

    #常见的布局方法

    1、table 表格布局:早期使用的布局,如今用得很少。

    2、float 浮动 + margin:为了兼容低版本的IE浏览器,很多网站(比如腾讯新闻、网易新闻、淘宝等)都会采用 float 布局。

    3、inline-block 布局:对外的表现是行内元素(不会独占一行),对内的表现是块级元素(可以设置宽高)。

    4、flex 布局:为布局而生,非常灵活,是最为推荐的布局写法。

    唯一的缺点是兼容性问题:

    上图中可以看到, flex 布局不支持 IE9 及以下的版本。如果你的页面不需要处理 IE浏览器的兼容性问题,则可以放心大胆地使用 flex 布局。

    flex 是一种现代的布局方式,是 W3C 第一次提供真正用于布局的 CSS 规范。

    5、响应式布局。

    #float 布局

    是 CSS 中一种比较麻烦的属性,涉及到 BFC 和清除浮动(面试的重点)。

    #float 属性的特点

    • 元素浮动

    • 脱离文档流,但不脱离文本流

    代码举例:

    下面这两个并列的div1div2,默认是在标准流中的:

    在此基础之上,如果给div1增加float: left属性后,效果如下:

    上图中,可以看到,div1设置为浮动后,会脱离文档流,不会对div2的布局造成影响;但是div1不会脱离文本流,它会影响div2中文字的排列。

    其实,这正是 float 属性的作用。float 本身是用来做图文混排、文字环绕的效果。

    #float 所带来的影响

    1、对自身的影响:

    • 形成“块”(BFC)

    • 位置尽量靠上

    • 位置尽量靠左/右

    下面这两个并列的div1div2,设置为浮动之后的效果:(都是尽量靠左显示的)

    在上方代码的基础之上,增加 div2的宽度之后,会发现,div2掉下来了:

    2、对兄弟元素的影响:

    • 不影响其他块级元素的位置

    • 影响其他块级元素的内部文本

    3、对父级元素的影响:

    • 从父级的布局中“消失”

    • 造成父级元素的高度塌陷:父级元素撑开 div1 之后(父级元素里没有其他元素的情况下),如果设置 div1 为 float 之后,,会让父级元素的高度变为0。

    #inline-block 布局

    对外的表现是行内元素(不会独占一行),对内的表现是块级元素(可以设置宽高)。

    思路:像文本一样去排列 block 元素,没有清除浮动等问题。

    存在的问题:需要处理间隙。代码举例如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
    	<meta charset="UTF-8">
    	<meta name="viewport" content="width=device-width, initial-scale=1.0">
    	<title>Document</title>
    </head>
    <style>
    	.container{
    		width: 300px;
    		height: 300px;
    		background: pink;
    	}
    
    	.div1{
    		width: 100px;
    		height: 100px;
    		background: green;
    		display: inline-block;
    	}
    
    	.div2{
    		width: 100px;
    		height: 100px;
    		background: yellowgreen;
    		display: inline-block;
    	}
    
    	.div3{
    		background: yellow;
    	}
    </style>
    
    <body>
    	<div class="container">
    		<div class="div1">div1的inline-block 属性</div>
    		<div class="div2">div2的inline-block 属性</div>
    		<div class="div3">
    			琴棋书画不会,洗衣做饭嫌累。
    		</div>
    	</div>
    </body>
    
    </html>
    
     

    上面的代码,存在两个问题。

    问题一:如果设置div2的宽度为 200px 之后,div2 掉下来。

    问题二:div1div2设置为 inline-block之后,这两个盒子之间存在了间隙。这是因为,此时的 div1div2 已经被当成文本了。文本和文本之间,本身就会存在间隙。

    为了去掉这个间隙,可以有几种解决办法:

    办法1:设置父元素container的字体大小为0,即font-size: 0,然后设置子元素 div1div2的字体font-size: 12px

    办法2:在写法上,去掉div1div2之间的换行。改为:

    <div class="div1">div1的inline-block 属性</div><div class="div2">div2的inline-block 属性</div>
    
     

    #响应式布局

    移动端用得较多,本文暂时先不讲。

  • 相关阅读:
    按键消抖电路设计——你们遇到的都是伪消抖
    FPGA工程中用C语言对文件进行处理_生成mif文件
    verilog中always块延时总结
    FPGA中改善时序性能的方法_advanced FPGA design
    verilog中连续性赋值中的延时
    verilog中读取文件中的字符串_modelsim高级仿真
    FPGA知识大梳理(四)FPGA中的复位系统大汇总
    c++虚函数几种实现方法
    c++逐渐退化的虚函数
    c++管理内存的几种方式
  • 原文地址:https://www.cnblogs.com/yzy521/p/14132772.html
Copyright © 2011-2022 走看看