CSS综合 杂谈

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

(例子六)

代码题
代码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,340评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,762评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,329评论 0 329
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,678评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,583评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,995评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,493评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,145评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,293评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,250评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,267评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,973评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,556评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,648评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,873评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,257评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,809评论 2 339

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,721评论 1 92
  • 一 外部式css样式 (也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css...
    KunMitnic阅读 921评论 0 1
  • 本文主要是起笔记的作用,内容来自慕课网. 认识CSS样式 CSS全称为“层叠样式表 (Cascading Styl...
    0o冻僵的企鹅o0阅读 2,601评论 0 30
  • CSS格式化排版 1、字体 我们可以使用css样式为网页中的文字设置字体、字号、颜色等样式属性。下面我们来看一个例...
    张文靖同学阅读 1,267评论 0 3
  • 收听音频,戳链接,旧号itclan已暂停使用,欢迎关注微信itclanCoder公众号可收听更多音频 前言 关于网...
    itclanCoder阅读 8,146评论 3 30