css垂直居中方法盘点
有些css属性虽然经常再用,但是基本概念久而久之却忘了。。。这篇博客就是一个笔记,时常回来看看,争取做到概念与运用都很熟练。
1、固定定位(fixed | absolute)
这两种定位方式都脱离了文档流,并且能够根据top、right、left、bottom属性进行定位。不同的是 fixed 是根据浏览器窗口的左上角为原点进行偏移定位的,也就是说它不会根据滚动条的滚动而进行偏移。而 absolute 参照的位置是离当前元素最近的定位方式为 fixed、absolute、relative 的祖先元素的左上角。
2、浮动:(float:left | right)
CSS中的定位机制有:普通流,浮动,绝对定位(暂时不讨论)
(1)普通流:很多人和文章称之为文档流,其实标准里根本就没有这个词。如果把文档流直译为英文就是 document flow ,但标准里只有另一个词,叫做普通流(normal flow)。现实中大家更习惯文档流的称呼,因为很多中文翻译的书就是这么来的。
(2)浮动:浮动的框可以左右移动,直至它的外边缘遇到包含框或者另一个浮动框的边缘。浮动框不属于文档中的普通流,当一个元素浮动之后,不会影响到块级框的布局而只会影响内联框(通常是文本)的排列,文档中的普通流就会表现得和浮动框不存在一样,当浮动框高度超出包含框的时候,也就会出现包含框不会自动伸高来闭合浮动元素("高度塌陷"现象)。顾名思义,就是漂浮于普通流之上,像浮云一样,但是只能左右浮动。正是因为浮动的这种特性,导致本属于普通流中的元素浮动之后,包含框内部由于不存在其他普通流元素了,也就表现出高度为0(高度塌陷)。在实际布局中,往往这并不是我们所希望的,所以需要闭合浮动元素,使其包含框表现出正常的高度。解决浮动带来的问题,很多人都已经习惯称之为清除浮动,但叫做闭合浮动比清除浮动更加严谨。
(3)闭合浮动的几种常见方法:
方法一:添加一个空的元素标签:<div class="clear"></div>;CSS:.clear{clear:both;height:0;line-height:0;font-size:0;}。
方法二:浮动元素的父级div元素设置:overflow:hidden | auto。
方法三:伪元素 ::after实现
.clearfix{zoom:1;}
.clearfix::after{content:'';clear:both;display:table;height:0;visibility:hidden;}。
3、css3选择器
这里只是列举一些日常开发中不是很常用,但是很重要的选择器。
(1)nth-child:
页面结构:ul.list1>li*5,这里就不详细写出来了。css如下:
.list1 li:nth-child(odd){
background:#f2f2f2; /*奇数行的背景色为#f2f2f2*/
}
.list1 li:nth-child(even){
background:#fff; /*偶数行的背景色为#fff*/
}
.list1 li:nth-child(5){
background:orange; /*第五行的背景色为orange*/
}
注意: &:nth-child 与 &:nth-of-type 的区别,见下面的栗子:
<section>
<h1>Words</h1>
<p>hello</p>
<p>test</p>
</section>
p:nth-child(odd) { color:#f00; } :奇结点
p:nth-child(even) { color:#00f; }:偶结点
p:nth-child(2) {color:orange;} :首先这是一个p标签,然后它是父节点的第二个子元素。hello的颜色为orange。
p:nth-of-type(2) {color:orange;} :选中父节点的第二个子p标签。test的颜色为orange。
(2)类名通配符
Class^= 匹配类名以指定值开头的每个元素。Class$= 匹配类名以指定值结尾的每个元素。Class*= 匹配类名中包含指定值的每个元素。及下面的例子:
div[class^='box-'] { color:red; }
div[class*='-box'] { color:orange; }
div[class$='-content'] { color:green; }
<div class="box-1">box-1</div><!-- 红色 -->
<div class="main-box">main-box</div><!-- 橙色 -->
<div class="main-content">main-content</div><!-- 绿色 -->
4、transform & transition & animation 简介:
transform:对元素进行变形;
transition:对元素某个属性或多个属性的变化,进行控制(时间等)。但只有两个关键贞。开始,结束。
animation:对元素某个属性或多个属性的变化,进行控制(时间等)。可以设置多个关键贞。
transition 与 animation 实现动画区别:transition 需要触发一个事件,而 animation 在不需要触发任何事件的情况下也可以显式的随着时间变化来改变元素css的属性值,从而达到一种动画的效果。
5、::-webkit-scrollbar:浏览器自带滚动条设置(美化/去掉)
::-webkit-scrollbar { display: none; /*隐藏滚动条*/ }
更多详情请参考:MDN ::-webkit-scrollbar Styling Scrollbars
6、伪元素 before/after 中的图片大小设置
例如:.box:before{ content:' '; background:url(icon.png); background-size:20px 20px; }
7、postcss:
它能够为 CSS 提供额外的功能;
通过在 PostCSS 这个平台上,我们能够开发一些插件,来处理我们的CSS,比如热门的:autoprefixer;
我们能够使用js来开发插件(这点对前端来说很重要)。
PostCSS本身只是一个API,使用js处理css。
css垂直居中方法盘点的更多相关文章
- 最常用的css垂直居中方法
css垂直居中一直以来都是一个被大家说烂了的话题,翻来覆去的炒.不过说实话,正是因为css没有提供标准的垂直居中方法(不过在css3中已经有了相关规范),所以大家才会对它进行专门的研究.这研究来研究去 ...
- css垂直居中方法
CSS垂直居中的简便方法:{position:absolute;left:0;bottom:0;top:0;right:0;margin:auto;}.
- css垂直居中方法总结
在网页布局中,我们往往会遇到下图所示的场景,让小图标和文字对齐 可能有的小伙伴会说,这个简单,直接给小图标设置左浮动来实现. 这样做是可以的,但不推荐,毕竟浮动是会影响布局的,能少用还是少用. 以前遇 ...
- css垂直居中方法(四)
第六种方法,使用css的writing-mode属性,结合margin:auto. 参考文章:改变CSS世界纵横规则的writing-mode属性 传统的web流中,margin设置auto值的时候, ...
- css 垂直居中方法总结
工作中遇到垂直居中问题,特此总结了一下几种方式与大家分享.本文讨论的垂直居中仅支持IE8+ 1.使用绝对定位垂直居中 HTML <div class="container"& ...
- css 垂直居中方法汇总
查看原文可以有更好的排版效果哦 前言 居中是平时工作中的最常见的一种需求,各种图片居中或者各种弹窗,水平居中还好,特别是垂直居中,很多初学者表示太难写了,现在列举一些常用的方法. 实战 这里只讲述cs ...
- [css] 垂直居中方法
原文链接:http://www.cnblogs.com/2050/p/3392803.html 一.text-algin:center; 适用于行内元素水平居中,如图片.按钮.文字, 但是在IE67下 ...
- css垂直居中方法(二)
第四种方法: 这个方法把一些div的显示方式设置为表格,因此我们可以使用表格的vartial-align属性. 代码如下: <!doctype html> <html lang=&q ...
- css垂直居中方法(一)
第一种方法:首先用margin:0 auto实现水平居中,然后设置position:relative,设置top为50%(父元素高度的50%),然后设置margin-top:-150px(设置负值是因 ...
随机推荐
- .Net4.0以上使用System.Data.Sqlite
最近对Sqlite感兴趣,就尝试了一下用c#连接,我用的版本是vs2013,默认开发环境是.net4.5,,按照网上的教材,下载了System.Data.Sqlite,然后写了下面这个简单的测试代码, ...
- charing animation
FHD : full high definition,1920 x 1080,全高清 vendor/mediatek/proprietary/bootable/bootloader/lk/dev/lo ...
- Web javascript 中常用API合集
来源于:https://www.kancloud.cn/dennis/tgjavascript/241852 一.节点 1.1 节点属性 Node.nodeName //返回节点名称,只读 Node. ...
- ubuntu中pycharm安装激活第二种方法的密钥
43B4A73YYJ-eyJsaWNlbnNlSWQiOiI0M0I0QTczWVlKIiwibGljZW5zZWVOYW1lIjoibGFuIHl1IiwiYXNza WduZWVOYW1lIjoi ...
- react native 图片样式导致的坑
最近项目中遇到一个问题,代码如下,点击进入另一个页面时需要显示的图片会黑屏,另外退回到该页面的时候下面代码中的第一个图片会全黑几秒才渲染,从另一个路径进入该页面时并没有此问题,就找了半天是不是数据的问 ...
- 思维导图FreeMind安装问题及简单使用
思维导图软件使用的坎坷之路 一直想将思维导图加入到工作环境当中 最开始使用的是 MindManager(http://www.mindmanager.cc/) ,而且感觉利用它制作出来的导图外观也比较 ...
- Beennan的内嵌汇编指导(译)Brennan's Guide to Inline Assembly
注:写在前面,这是一篇翻译文章,本人的英文水平很有限,但内嵌汇编是学习操作系统不可少的知识,本人也常去查看这方面的内容,本文是在做mit的jos实验中的一篇关于内嵌汇编的介绍.关于常用的内嵌汇编(AT ...
- 自己写的服务出现"服务没有及时响应启动或控制请求 1053" 错误
自己写了一个服务,安装到电脑上后 启动时发现报"服务没有及时响应启动或控制请求 1053" 这个错误 在网上找了一些方法,都没有解决 后来,看了下,原来有个写文件的方法读取文件没有 ...
- 特性 Attribute
特性就是一个类,必须是Attribute的子类 一般以Attribute结尾,然后在使用的时候,可以去掉这个结尾 可以在特性中声明字段.属性.方法.构造函数.委托.事件... [AttributeUs ...
- JavaWeb学习笔记——过滤器
JSP可以完成的功能Servlet都可以完成,但是Servlet具备的很多功能是JSP所不具备的. 从使用上来看,Servlet可以分成简单Servlet.过滤Servlet(过滤器)和监听Servl ...