CSS综合 杂谈

作者: 在乎者也 | 来源:发表于2017-08-25 12:13 被阅读26次

1. 说一说你平时写代码遵守的编码规范

我是借鉴腾讯AlloyTeam团队代码规范 再结合公司以前定制的方案 编写自己的代码。
代码不仅要能够运行实现功能,产品出来后还有不断的更新迭代 维护的很长一段过程 公司都是团队工作 规范化后
review 代码的时候就在心中有一套规范去查看代码 能够节省debug 查阅代码 沟通中产生的时间成本

2. 垂直居中有几种实现方式,给出代码范例

开始好奇
margin: 0 auto 可以 使块级元素水平居中 ·margin:auto 0 应该能使块级元素垂直居中,然而不行
例子1
不行的原因
CSS2的标准:计算高度时如果 margin-top 或 margin-bottom 的值为 auto, 则他们值为0

计算高度时如果 `margin-top` 或 margin-bottom 的值为 `auto`, 则他们值为0

开始思考
既然 auto不能用,于是自己这是 利用calc计算出元素居中的距离 向下移动 50% 在少移动自身高度一半 居中
例子2
CSS2的标准:如果使用百分比作为 margin-top的值,则百分比的基准是父元素的 宽度 宽度 宽度 是不是很蒙蔽
解决问题?
记得我们目的是让 元素向下移到居中的高度 margin-top是按父元素的宽度算 但是还有定位 的 top/bottom 是按父元素的高度算
例子三
真的解决问题?
设计说,帮忙在居中元素里面增加点内容,内容不固定 高度也可能会超过你设定的元素 你减去的元素高度是不固定的 这样就无法计算你要移动的高度了 所以没有真的解决问题(当然上面也是一个固定场景解决垂直居中的方法)

image.png

再次陷入深深的思考
在css属性里找呀找 找呀找 找呀找
找到一个属性名 为 vertical-align, 而且它还有个值 是 vertical-align: middle! 用了用 然而并没卵用

查看文档: vertical-align是用来指定行内元素 和 table-cell 的垂直对齐方式;

尝试: 将元素转化为table 父元素加上 display: table, 为子元素 加上 display: table-cell 来将他们变成表格的样式, 在为子元素加上 vertical-align: middle
例子4
居中了 而且也跟子元素的实际高度无关 兼容性还好, 但是父元素的宽度变小了 原因是 table 本质上也是 inline 元素, 因此现在变成inline的父元素, 他的宽度将与子元素的宽度相同。 到时也可以在父元素加上 width: 100% 来强制指定宽度 (使用inline-block注意解决间隙问题)

另一个问题是子元素的高度变得和父元素一样高了。这对读者而言也许是问题,也许不是,就要自己考虑了

拥抱CSS3

之前我们用过 position: relative + top: calc(50% - height/2)的方法, 但是这种方法的缺点是需要知道子元素的高度, 但有了 transform 我们就可以用 translateY(-50%)来达到 -height/2 的 目的 而不需要知道居中元素的高度

例子五

真正的解决问题了么

<div class="container">
  <div class="vertical">
    <p id="p1"> A paragraph 1 </p>
    <p id="p2"> A paragraph 2 </p>
  </div>
</div>

如上 HTML 文件,我们为了居中 p1 和 p2,而为它们加了一个层包裹层 .vertical。虽然也不是什么难事,但在某些情形下,我们是不能修改文档的结构的,其中一种可能是文档的内容是动态生成的。也就是,我们希望在现有的文档结构下,让某些内容垂直居中,这也许是最后一个痛点了。

那么下面我们就来看看最终的杀器:flexbox。

真正解决问题(依然有兼容烦扰, 可以降级选择以上能够兼容方法)
解决问题三行代码, 足矣。。。。

image.png

(例子六)

代码题
代码

相关文章

  • CSS综合 杂谈

    1. 说一说你平时写代码遵守的编码规范 我是借鉴腾讯AlloyTeam团队代码规范 再结合公司以前定制的方案 编...

  • 杂谈综合

    慎独 众行 清华大学校长王希勤寄语:“慎独不孤,众行能远。以己为鉴、认知自我,慎独方能养德;以朋为友、融入集体,志...

  • CSS杂谈

    1. inline、block和display:inline-block block和inline这两个概念是简略...

  • css杂谈

    j#### text-align: center的作用是什么,作用在什么元素上?能让什么元素水平居中作用:定义行内...

  • CSS 杂谈

    CSS 杂谈 文档流 Normal Flow 流动是默认的网页布局形式。也就是说在默认状态下的HTML网页元素都是...

  • CSS杂谈

    本文没有什么高深的东西,就是写几个CSS样式经常遇见的东西,可能大部分都已经知道怎么解决了,当做小白文浏览就好。 ...

  • CSS杂谈

    关于浏览器乱码 说法正确的有 用不合适的编辑器编辑文件,常常会出现乱码,比如windows 记事本 html保存的...

  • CSS综合

    1、 前端编码规范 HTML书写规范 所有编码均遵循xhtml标准, 标签 & 属性 & 属性命名 必须由小写字母...

  • css综合

    1.说一说你平时写代码遵守的编码规范 1.1 标签语义化 1.2 tab用两个空格表示 1.3 不在自闭和的元素末...

  • CSS 综合

    1.平时写代码遵守的编码规范 tab 用两个空格表示 css的 :后加个空格, {前加个空格 每条声明后都加上分号...

网友评论

    本文标题:CSS综合 杂谈

    本文链接:https://www.haomeiwen.com/subject/rgyedxtx.html