博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
css笔记(二)——几种经常使用的模式
阅读量:6539 次
发布时间:2019-06-24

本文共 2539 字,大约阅读时间需要 8 分钟。

文本垂直居中

对于行内元素,height会自己主动收缩到包裹住文本的高度,所以不存在这个问题。

可是对于block和inline-block等盒子元素。假设设置了height属性,则文本默认会在上方显示。

假设希望文本在垂直方向上居中,能够设置line-height属性等于height属性。或者大于height属性

hello world
div {    height: 200px;    line-height: 200px;}

文本水平居中。图标分列左右两側

效果是左側一个小箭头,右側一个小箭头,日期显示在中间

<
2014年5月11日
>
#wrapper{    text-align: center;    position: relative;    width: 200px;}#wrapper > span:first-child{    float: left;}#wrapper > span:last-child{    float: right;}
假设给2个float元素设置width(比方为了增大点击区域的目的),则width应该设置成一样,否则会破坏日期水平居中的效果

为float元素设置width

一般来说。行内元素(如span)。会自己主动收缩以适应文本宽度,为其设置width属性是无效的。可是当span元素被float了之后。就能够为其设置width属性了

盒子有多大

对于块元素,如block和inline-block。假设不设置其width。则会自己主动扩展到父容器的宽度。此时设置它的padding和border,不会改变盒子的大小(还是和父容器一样宽),可是会缩小content的宽度

abc
#parent {    widht: 200px;}#son {    padding: 1px;    border: 1px solid black;}
son的width自己主动扩展到200px。然后因为padding和border占了4px,内容区域就是196px

假设设置了son的width。实际上设置的是content的width。加上border和padding后,实际的宽度会超过父容器

#son {    width: 200px;    padding: 1px;    border: 1px solid black;}
content的宽度是200px。加上border和padding的4px。最后盒子的宽度是204px

可是,假设设置box-sizing为border-box。则设置的width就变成了整个盒子的宽度,此时再设置border和padding。又会缩小content的宽度了

#son {    box-sizing: border-box;    width: 200px;    padding: 1px;    border: 1px solid black;}
实践中,在全局设置box-sizing为border-box挺不错的。这样设置padding和border时,就不用操心造成盒子宽度的变化了

水平排放li

  • 1
  • 2
  • 3
  • 4
  • 5
ul{    font-size: 0;}li{    font-size: 1rem;    display: inline-block;    width: 20%;}
这里的一个技巧是设置ul的font-size为0。由于</li>和<li>之间有空隙,在大部分浏览器上都会造成1px的间隙。造成一行无法容纳5个li,于是最后一个li元素就会掉到下一行。因此把ul的font-size设置成0,在li中再恢复,能够避免此1px问题。用inline-block方式实现水平布局,大多都会有这个问题

N列固定比例水平布局

有点类似上面的li平铺

div {    font-size: 0;}div > * {    display: inline-block;    font-size: 1rem;    vertical-align: top;}div > nav {    width: 30%;}div > div {    width: 50%;}div > aside {    width: 20%;}
基本上和li平铺的模式全然一样,差别是设置全部的子元素vertical-align: top。

否则当各子元素的高度不一致时。看起来似乎没有在同一行。其有用dev tools能够看出来,3个子元素还是在同一行,仅仅是在垂直方向上没有对齐。设置vertical-align能够解决此问题

某些列宽度固定,其它列宽度比例固定的水平布局

div {    display: -webkit-box;}div > nav {    width: 200px;}div > div {    -webkit-box-flex: 1;}div > aside {    -webkit-box-flex: 2;}

长处是不会出现1px问题。也不须要设置子元素为inline-block。非常方便。另外。设置display: box之后,子元素会自己主动变成等高。

这在某些场景下非常方便,可是也不适用于另外一些场景。最后display: box,在老的浏览器上支持不好,所以这样的方式没有老技巧那么通用。可是随着浏览器日趋标准,我认为慢慢就不是问题了

转载于:https://www.cnblogs.com/yutingliuyl/p/6962248.html

你可能感兴趣的文章
POJ3321 Apple Tree (树状数组)
查看>>
protocol buffers的编码原理
查看>>
行为型设计模式之命令模式(Command)
查看>>
减少死锁的几个常用方法
查看>>
HDFS 核心原理
查看>>
正确配置jstl的maven依赖,jar包冲突的问题终于解决啦
查看>>
利用KMP算法解决串的模式匹配问题(c++) -- 数据结构
查看>>
登录内网账号后,连接不上内网网址
查看>>
安装 MariaDB
查看>>
【deep learning学习笔记】注释yusugomori的DA代码 --- dA.h
查看>>
Ubuntu 12.04 root用户登录设置
查看>>
windows核心编程-互斥器(Mutexes)
查看>>
纯手工打造漂亮的垂直时间轴,使用最简单的HTML+CSS+JQUERY完成100个版本更新记录的华丽转身!...
查看>>
java 为啥变量名前要加个m?
查看>>
探索Android中的Parcel机制(上)
查看>>
c++ 类型定义
查看>>
C#开发微信门户及应用(5)--用户分组信息管理
查看>>
怎样实现前端裁剪上传图片功能
查看>>
程序员提高工作效率的15个技巧【Facebook】
查看>>
ffmpeg+SDL2实现的视频播放器「退出、暂停、播放」
查看>>