前端面试准备--2.css盒模型

css盒模型

1.题目:谈谈你对css盒模型的认识(从理论转化到应用)

  • 基本概念:标准模型+ IE模型
    border、margin、padding、content
  • 标准模型
  • IE模型

1、标准模型和IE模型区别

1.计算宽度和高度的不同,怎么不同的,怎么计算的;

  • 标准模型的宽度是:content的宽度,不包含padding和border
  • IE模型的宽度是:宽和高是计算 border 和 padding 的

css如何设置这两种模型:

box-sizing:content-box;(标准模型--浏览器默认)
box-sizing:border-box;(IE模型)

JS如何设置获取盒模型对应的宽和高

  1.dom.style.width/height(只能取内联样式的宽和高)
      ----getElementById('div').style.width/height
            
  2.dom.currentStyle.width/height
     (渲染之后的宽高--只有IE支持)
        
  3.window.getComputedStyle(dom).width/height
    (渲染之后的宽高--兼容性通用型更好一些)
            
 4.dom.getBoundingClientRect().width/height
       (适用场景:计算一个元素的绝对位置;这个绝对位置根据视窗
也就是左上角这个位置的绝对位置) 这个方法可以拿到四个元素:left top width height

实例题:(根据盒模型解释边距重叠)

一.要看父元素的盒模型怎么设置的:

1.父子元素边距重叠

overflow:hidden;解决重叠问题;相当于给父元素创建了一个BFC(块级格式化上下文)

    eg:子元素高度为100px,距父元素顶部10px,计算父元素的高度?
    1.因为父元素和子元素存在边距重叠,所以父元素高度为100px;
    2.设置了overflow:hidden;之后父元素高度为110px;

2.兄弟元素边距重叠

兄弟元素每个都有上边距或者下边距,发生重叠原则取最大值;

    eg:一个元素下边距为30px,下面那个元素上边距为5px,会合并成30px两者取最大值

3.空元素

空元素设置上下边距,margin-top\margin-bottom取一个最大值,作为它的一个边距

4.BFC(边距重叠解决方案)--另一种IFC

BFC基本概念:块级格式化上下文

  • BFC的原理(渲染规则):

1.在BFC这个元素的垂直方向的边距会发生重叠
2.BFC的区域不会与浮动元素的相重叠(清除浮动布局)
3.BFC在页面是一个独立的容器,外面的元素不会影响它里面元素,反过来一样
4.计算BFC高度的时候浮动元素也会参与计算

  • 如何创建BFC?

1.overflow:hidden | auto | visible
2.float值不是null(只要有浮动,当前元素就创建了BFC)
3.position值不是static或者relative就创建了BFC(设置成absolute,fixed)
4.display属性是为inline-box,table-cell(也就是和table相关的)

  • BFC使用场景有哪些?

1.父级元素里面有三个子元素,子元素margin:5px auto 25px;
之后就第一个元素的上边距是5,其他的都是25px,这有一个边距重叠的问题;在写页面布局的时候不想有这个重叠,就给子元素增加一个父元素,父元素创建一个BFC就能解决问题;

2.布局相关的BFC应用

  • BFC垂直方向边距重叠

垂直方向三个p元素,p{margin:5px auto 25px},之后第二个第三个的上边距变成25px;发生了边距重叠,取得的是最大值;如果不想重叠,就需要再那个元素在加一个父级div,对父级div创建BFC(overflow:hidden)

  • BFC不与float重叠

两栏布局,左边宽度固定左浮动height:100px,右边自适应height:120px;右边的高度增高的时候,右边的背景色已经侵染到了左侧,(当布局的时候左侧没有float元素,它依然会往左侵染),解决方法:给右侧元素创建一个BFC(overflow:atuo)

  • 清除浮动;(BFC子元素即使是float元素也会参与计算)

       .layout{background:orange}
       .float{float:left;}
    
    -->只看到.float的内容没看到父级的背景颜色;父级高度为0;
    --->一个普通的元素当子元素是float元素的时候,它的高度计算没有包含进来;
    
    .layout{background:orange;overflow:hidden;}
    .float{float:left;}
    
    --》给layout设置BFC之后,float内容有了背景颜色,父级有了高度;
    ---->当把外层元素设为BFC的时候,子元素的浮动元素也会参与父级的高度计算;
    
  • BFC的元素在计算高度的时候会考虑内部子元素float
    (子元素是float也不影响父元素高度的计算,它的内容页会被参与进来)

  • --IFC(内联元素的格式化上下文)

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

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,725评论 1 92
  • 题目:谈谈你对css盒模型的认识? 答: 基本概念:padding,margin,border,content 标...
    noyanse阅读 304评论 0 0
  • 1.浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 何谓浮动元素?有什么特征?所谓浮动...
    草鞋弟阅读 808评论 0 1
  • 一,浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动模型是一种可视化格式模型,浮动...
    DeeJay_Y阅读 855评论 0 4
  • 紫藤香韵金盘舒 绿玻微凉 鸽子频比翼 朝阳深晓离别苦 急穿轻云朱辉谱 昨夜青虫凋碧蔬 独上菜场 买断叶几株 欲寄化...
    译繁星空阅读 291评论 1 2