css问题记录

margin: 0 auto失效的原因

  • 元素没有宽度
  • 元素浮动
  • 元素绝对定位(脱离文档流),注意:相对定位不会失效
  • 元素display属性为table-cell,table-cell元素对margin无感

使absolute元素的文字内容宽度自适应

absolute元素宽度高度并不能依据内容自适应。在元素只有文字内容时定位元素,发现出现中文排成了一列而不是一行的问题,可以通过强制文字不换行解决这个问题。

.text-nowrap{
  white-space: nowrap;
}

inline和inline-block元素并排时存在水平空隙

使用百分比布局时,发现40%和60%的inline-block元素并不能排列于一行,这是因为它们之间存在间隙。可以通过设置父元素的font-size为0解决问题。

.clear-inline-hspace{
  font-size: 0;
}

这些空白间隙实际上是html标签中的空白符,如果把标签之间的回车换行空格都删除掉也可以解决问题。

line-height会影响所有inline-block元素高度

line-height的改变会造成inline-block元素的高度改变,这可能带来布局上的问题。所以,在使用许多inline-block元素的复杂布局中,最好不要先设置容器的padding和height,应该先设置内部高度(可能使用line-height)后再考虑是否使用padding。

margin-top和margin-bottom失效

对于inline元素而言,设置margin-top和margin-bottom是无效的。

设置margin-top导致父元素出现空白的解决方法

在父容器中设置溢出隐藏

.ofw-hidden{
  overflow: hidden;
}

margin和float会使布局变乱

<style>
.top {
    background-color: blue;
}
.bottom {
    height: 100px;
    background-color: red;
}
p {
    float: right;
    margin-bottom: 10px;
}
</style>
<div class="top">
    top
    <p>This is the top content</p>
</div>
<div class="bottom"></div>

结果:

image.png

这是因为p浮动脱离文档流,它不会撑开容器,设置的margin也无效。

margin重叠

参考文章

fixed失效问题

  • 祖先元素含transform
    当布局未fixed的元素遇到祖先元素设置了transform属性时,但对于该祖先元素定位,而不是相对于浏览器可视窗口。
  • 祖先元素含will-change: transform
    情况同transform

负margin

负数margin会导致子元素超出容器,可能导致布局问题,所以尽量少用负margin;即使要用,也尽量在容器中使用。

box-sizing

padding+width大于窗口宽度,会导致空白问题,可以使用box-sizing: border-box快速解决。

flex布局

flex布局会使元素的高度相同,如果水平并列的元素宽度不同,需要添加一层容器包裹子元素。

头部fixed的占位问题

如果要自定义实现position: sticky的头部导航效果,通过js切换static和absolute,会导致导航条出现抖动问题。一种比较好的方法是使用一个空白的div进行占位,头部定位保持fixed就可以了。

/**
  fixed元素占位
  @param {DOM} el fixed元素
  @param {String} pos 插入占位元素的位置
*/
function fixFixedSpace (el, pos = 'append') {
  const pass = document.createElement('div')
  const parent = el.parentNode
  pass.cssText = `width: ${pass.offsetWidth}px; height: ${pass.offsetHeight}px;`
  if (pos === 'append') {
    parent.appendChild(pass)
  } else if (pos === 'prev') {
    parent.insertBefore(pass, el)
  } else if (pos === 'next') {
    parent.insertBefore(pass, el.nextSibling)
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,029评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,395评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,570评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,535评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,650评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,850评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,006评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,747评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,207评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,536评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,683评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,342评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,964评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,772评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,004评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,401评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,566评论 2 349

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,737评论 1 92
  • 1. 前言 前端圈有个“梗”:在面试时,问个css的position属性能刷掉一半人,其中不乏工作四五年的同学。在...
    YjWorld阅读 4,428评论 5 15
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,450评论 1 45
  • 以下文章是我在网上收集的内容,为了记录自己的学习以及为了以后不到处找而记录下来,如果对你有用,请感谢写这些文章的前...
    DCbryant阅读 927评论 0 2
  • 世人皆称吾为仙,而我无双却为魔。 魔比仙好。
    路人皆知甲乙丙阅读 286评论 0 0