CSS 常用的定位和布局方法汇总(已添加源码地址)
CSS-Layout
旨在打造详尽的前端布局代码学习库(自从用了框架开发,CSS生疏了不少,所以开这个库练练手)
SF不能正确解析含有中文的网址,所以某些预览链接无法跳转,请访问我的博客阅读此文
常见定位方法
水平居中
子元素为行内元素还是块状元素,宽度一定还是宽度未定,采取的布局方案不同。
方案选择基本思路:
子元素为
行内元素:对父元素设置
text-align:center
;定宽块状元素: 设置左右
margin
值为auto
;不定宽块状元素: 设置子元素为
display:inline
,然后在父元素上设置text-align:center
;通用方案: flex布局,对父元素设置
display:flex;justify-content:center
;
常用方法举例:
NOTE:为了统一展示效果,在以下实例代码中对父子元素设置了固定宽高,实际可以不设置,由子元素内容来控制其宽度
设置:对父元素设置text-align:center
(将会对行内元素起作用),子元素设置display:inline-block
(兼容IE6、7 时,替换为display:inline;zoom:1;
);
优点:兼容性良好
缺点: 需要额外代码修复因继承父元素的text-align:center
对子元素内容排列造成的影响,如需要添加.child{text-align:left}
方法二:table + margiin
设置:对子元素设置display:table
(此元素会作为块级表格来显示,元素表现类似block,但是宽度跟随内容宽度)(兼容IE6、7 时,替换div
结构为table
结构即可);
优点: 只需要对子元素进行设置
缺点: 向下兼容IE6、7时,需要更改html结构
设置:对父元素设置position:realatve
(使其作为参照物),对子元素设置position:absolute;left:50%
(绝对定位元素的宽度也随内容而定),然后对子元素设置transform:translateX(-50%)
(兼容IE6、7 时,替换div
结构为table
结构即可);
优点: 居中元素不会对其他元素造成影响
缺点:transform
不兼容低版本IE
设置:对父元素设置display:flex;justify-content:center
(这样其内部的元素会变为align-items
),align-items
的宽度默认为auto
,所以跟随内容宽度变化,继而justify-content:center
属性会使子元素居中
优点:只需要对父元素进行设置
缺点:flex
不兼容低版本IE
垂直居中
垂直居中对于子元素是单行内联文本、多行内联文本以及块状元素采用的方案是不同的。
父元素一定,子元素为单行内联文本:设置父元素的
height
等于行高line-height
父元素一定,子元素为多行内联文本:设置父元素的
display:table-cell
或inline-block
,再设置vertical-align:middle
;块状元素:设置子元素
position:absolute
并设置top、bottom
为0,父元素要设置定位为static以外的值,margin:auto
;通用方案: flex布局,给父元素设置
{display:flex; align-items:center;}
常用方法举例:
设置:子容器高度不固定,对父元素设置display:table-cell
(parent变为单元格,),继续设置vertical-align:center
(使inline元素垂直居中);
优点:兼容性好(支持 IE 8)
缺点:IE 8 以下版本需要调整页面结构至 table
设置:对父元素设置position:realatve
(使其作为参照物),对子元素设置position:absolute;left:50%
(绝对定位元素的宽度也随内容而定),然后对子元素设置transform:translateY(-50%)
(兼容IE6、7 时,替换div
结构为table
结构即可);
优点: 居中元素不会对其他元素造成影响
缺点:transform
不兼容低版本IE
设置:对父元素设置display:flex
(align-items默认属性为stretch),继而设置align-items:center
即可;
优点: 只需要对父元素进行设置
缺点:flex align-items
不兼容低版本IE
水平居中且垂直居中
结合以上介绍到的水平和垂直居中方法进行设置
多列布局
一列定宽,一列自适应宽度
1.一列定宽,一列自适应宽度(float+margin)
2.一列定宽,一列自适应宽度(float+margin)fix 改良版
NOTE:此方法不会存在 IE 6 中3像素的 BUG,但 .left 不可选择, 需要设置 .left {position: relative} 来提高层级。 此方法可以适用于多版本浏览器(包括 IE6)。缺点是多余的 HTML 文本结构。
3.一列定宽,一列自适应宽度( float + overflow )
4.一列定宽,一列自适应宽度( table + table-cell )
5.一列定宽,一列自适应宽度( flex )
多列定宽,一列自适应宽度
基于上面对于一列定宽一列自适应的需求实现,多列定宽只需要在原有一列定宽的基础上添加新的列即可,最后的列依然会自适应剩余宽度。
以 flex 的实现为基础可以作如下改造:
<div class="parent">
<div class="left">
<p>.left</p>
<p>左侧定宽</p>
</div>
<!--添加了一列,CSS与 .left 公用-->
<div class="center">
<p>.center</p>
<p>第二列定宽</p>
</div>
<div class="content">
<p>.content</p>
<p>flex:1 充满剩余空间,形成自适应效果,不设置的话默认为内容宽度</p>
</div>
</div>
<style>
.parent {
display: flex;
}
.left,.center {
width: 300px;
height: 500px;
margin-right:10px;
background-color: lightblue;
}
.content {
flex: 1;
height: 500px;
background-color: orange;
}
</style>
多列不定宽,一列自适应宽度
基于以上一列定宽一列自适应的实现,进行改造,左侧不定宽区域的宽度任意(也可以由内部的内容来决定宽度就可以实现不定宽且自适应),继续增加一列即可变为多列,都很方便实现
多列等分布局
1.多列等分布局(float)
2.多列等分布局(table)
3.多列等分布局(flex)
多列等高布局
1.多列等高布局(table)
2.多列等高布局(flex)
全屏布局
1.弹性全屏布局(position)
2.弹性全屏布局(flex)
3.百分比布局,以上宽度设置更改为百分比即可
4.根据内容完全自适应,position有限制无法满足,flex可以做到
CSS 常用的定位和布局方法汇总(已添加源码地址)的更多相关文章
- eclipse添加源码的另外一种方法
当我们使用maven或者gradle时,我们不需要担心源码的问题.Maven会帮我们下载jar包的同时下载对应的源码包.一般为source.jar,比如servlet-api-2.5-sources. ...
- CSS入门教程——定位(positon)
CSS入门教程——定位(positon) CSS定位在网页布局中是起着决定性作用. 定位 CSS的定位功能是很强大的,利用它你可以做出各种各样的网页布局.本节就介绍一些CSS常用的定位语句. 1. ...
- css布局 - 两栏自适应布局的几种实现方法汇总
这种两列布局的样式是我们在平时工作中非常常见的设计,同时也是面试中要求实现的高频题.很有必要掌握以备不时之需: 整理了几种实现方法,当然,风骚的代码不止这几种能实现,欢迎各位的补充. 方法汇总目录 简 ...
- CSS常用背景图片定位方法
CSS背景图片定位其实对于每一位学习前端的同学来说,都已经非常熟悉了.网上铺天盖地的最常见的一种方案就是在父元素中relative,然后子元素absolute.这种方案当然好,不过带来的一个缺点就是会 ...
- CSS易混淆知识点总结与分享-定位与布局
CSS定位有四种模式:static.relative.absolute.fixed,其它static是默认值,下面分别讲解下各自的特点: static:静态定位,处于动态布局流中,按照页面中的各元素先 ...
- css 常用布局
「前端那些事儿」③ CSS 布局方案 我们在日常开发中经常遇到布局问题,下面罗列几种常用的css布局方案 话不多说,上代码! 居中布局 以下居中布局均以不定宽为前提,定宽情况包含其中 1.水平居中 a ...
- Web前端篇:CSS常用格式化排版、盒模型、浮动、定位、背景边框属性
目录 Web前端篇:CSS常用格式化排版.盒模型.浮动.定位.背景边框属性 1.常用格式化排版 2.CSS盒模型 3.浮动 4.定位 5.背景属性和边框属性 6.网页中规范和错误问题 7.显示方式 W ...
- jquery常用函数与方法汇总
1.delay(duration,[queueName]) 设置一个延时来推迟执行队列中之后的项目. jQuery1.4新增.用于将队列中的函数延时执行.他既可以推迟动画队列的执行,也可以用于自定义队 ...
- CSS定位与布局:浮动
浮动的特点 浮动(float)属性提出的作用是实现文字的环绕效果,一个元素浮动后,会脱离普通流.主要的特点如下: 浮动的元素会向左或者向右移动直到它的外边缘接触容器框(containing blo ...
随机推荐
- LeetCode-081-搜索旋转排序数组 II
搜索旋转排序数组 II 题目描述:已知存在一个按非降序排列的整数数组 nums ,数组中的值不必互不相同. 在传递给函数之前,nums 在预先未知的某个下标 k(0 <= k < nums ...
- WPF子窗体
效果: 1. 点击WPF主窗体上的一个按钮,弹出子窗体, 2. 窗体最小化后,在菜单栏中点击子窗体,会连带显示它所从属的主窗体. 1. 在WPF项目中,已有主窗体MainWindow,再新建子窗体Ch ...
- 【故障公告】龙卷风来袭:突增的并发请求,撑不住的CPU
(上图是数据库连接数监控图) 非常抱歉,今天下午 16:50-17:40 期间,一场龙卷风突袭园子,突增的并发请求狂卷博客站点的 pod,由于风力巨大(70%左右的增量),pod 的 cpu 不堪重负 ...
- 伪静态 伪装成静态的网址,只是改变URL的表现形式,实际上还是动态页面
路由 Route::get('/list_{id}.html','newsController@listoNewone'); 页面详情 <table class="table" ...
- Linux——vi命令详解
转载 Linux--vi命令详解 原文链接:https://blog.csdn.net/cyl101816/article/details/82026678 vi编辑器是所有Unix及Linux系 ...
- git使用命令行保留原分支迁移代码仓库
有些时候我们需要对git仓库中的项目进行一些迁移,如从a账号迁移到b账号下,从github平台迁移到内部的gitlab平台等.一般平台会自带 migrate 或者 import 的功能,可以很方便的进 ...
- Numpy库基础___五
Numpy数据存取 •NumPy的随机数函数 a = np.random.rand(1,2,3) print(a) #[[[0.03339719 0.72784732 0.47527802] # [0 ...
- 开源版-阿里云人脸搜索M:N,人脸比对1:1
一.人脸搜索概要 本项目是阿里云视觉智能开放平台的人脸1:N的开源替代,项目中使用的模型均为开源模型,项目支持milvus和proxima向量存储库,并具有较高的自定义能力. 项目使用纯Java开发, ...
- 74CMS 3.0 存储型XSS漏洞
一. 启动环境 1.双击运行桌面phpstudy.exe软件 2.点击启动按钮,启动服务器环境 二.代码审计 1.双击启动桌面Seay源代码审计系统软件 2.因为74CMS3.0源代码编辑使用GBK编 ...
- dedecms 5.7 任意前台用户修改漏洞
一. 启动环境 1.双击运行桌面phpstudy.exe软件 2.点击启动按钮,启动服务器环境 二.代码审计 1.双击启动桌面Seay源代码审计系统软件 2.点击新建项目按钮,弹出对画框中选择(C:\ ...