#parent { width: 100px; height: 100px; background:black; overflow: hidden; } #child { height: 100px; border-left: 10px solid yellow; padding-right: 10px; padding-left: 10px; margin-left: 10px; background: red; }
效果图以下:
css
盒模型以下:
html
position:relative,定位的起始位置是该元素原先在文档流的位置。css3
浏览器的渲染过程:下载html—>解析DOM树—>渲染树—>带位置和形状信息的渲染树(布局)—>可见图形(渲染)
分析:下载过程当中,不只仅是一个文件,包括img,frame,script,web
渲染的流程基本上以下(黄色的四个步骤):gulp
1xx(临时响应) 表示临时响应并须要请求者继续执行操做的状态代码
2xx (成功) 表示成功处理了请求的状态代码。
3xx (重定向) 表示要完成请求,须要进一步操做。 一般,这些状态代码用来重定向
4xx(请求错误)表示请求可能出错,妨碍了服务器的处理。
5xx(服务器错误)表示服务器在尝试处理请求时发生内部错误。 这些错误多是服务器自己的错误,而不是请求出错。浏览器
Repaint——屏幕的一部分要重画,好比某个CSS的背景色变了。可是元素的几何尺寸没有变。服务器
Reflow——意味着元件的几何尺寸变了,咱们须要从新验证并计算Render Tree。是Render Tree的一部分或所有发生了变化。这就是Reflow,或是Layout。(HTML使用的是flow based layout,也就是流式布局,因此,若是某元件的几何尺寸发生了变化,须要从新布局,也就叫reflow)reflow 会从这个root frame开始递归往下,依次计算全部的结点几何尺寸和位置,在reflow过程当中,可能会增长一些frame,好比一个文本字符串必需被包装起来。
在一些高性能的电脑上也许还没什么,可是若是reflow发生在手机上,那么这个过程是很是痛苦和耗电的。css3动画
因此,下面这些动做有很大可能会是成本比较高的。闭包
当你修改网页的默认字体时。app
display:none会触发reflow,而visibility:hidden只会触发repaint,由于没有发现位置变化。
基本上来讲,reflow有以下的几个缘由:
Dirty。几个Incremental的reflow发生在同一个frame的子树上。
闭包是指有权访问另外一个函数做用域中的变量的函数,建立闭包的常见方式:在一个函数内部建立另外一个函数。
封装、命名污染
复用性、团队协做
省略号
ext-overflow:ellipsis; white-space:nowrap; //强制文本在一行内显示 overflow:hidden;
一列定宽一列自适应
若是是两列布局:能够直接把浮动的元素写在不浮动的元素前面
方法一:float
方法二:负margin
方法三:定位
CSS的元素分类中能够分红三种:行内元素(内联元素)、块级元素、以及内联块元素
(2)block level的元素
IE7及如下浏览器对块级元素(block element)的支持并不彻底,它们只支持用display:inline-block去定义一个inline level的元素为内联块。先将block level元素设置为inline,而后再去触发该元素的hasLayout,使其拥有和inline-block类似的特性。能够这样写:
<div id="demo"> <div>我是一个div</div> <div>我是一个div</div> <div>我是一个div</div> <div>我是一个div</div> </div>
#demo div{ display:inline-block; *display:inline; /*IE7 hack*/ *zoom:1; /*触发hasLayout*/ }
ASCII 空格 ( )
ASCII 制表符 ( )
ASCII 换页符 ( )
零宽度空格 ()
W3C中规定
一、折行被定义为一个回车,一个换行符,或者一个回车、换行的组合,全部的换行构成了空白行。
二、对于多个连续的空白符(空格、换行符、回车符),浏览器会将他们合并为一个空白符。
方法一:移除标签间的空格,写成一行
方法二:取消标签闭合
例如在美团webapp页面中貌似也是用到了这种方法。能够看下:
方法三:使用font-size:0;
在父容器上使用font-size:0;能够消除间隙,能够这样写:
<div class="demo"> <span>我是一个span <span>我是一个span <span>我是一个span <span>我是一个span</span> </div>
.demo {font-size: 0;} .demo span{ background:#ddd; display: inline-block; font-size: 14px; /*要设置相应的字号*/ }