当前位置: 首页 > news >正文

广东企业网站建设价格最近几天的重大新闻事件

广东企业网站建设价格,最近几天的重大新闻事件,泸州做网站的公司,英文网站怎么做外贸推广一次在前端面试中问到优化前端性能的方式 一、主要通过两种方式: reflow(回流)和repaint(重绘)。整个在浏览器的渲染过程中(页面初始化,用户行为改变界面样式,动画改变界面样式等)reflow(回流)和repaint(重绘) 会大大影…

一次在前端面试中问到优化前端性能的方式

一、主要通过两种方式: reflow(回流)和repaint(重绘)。整个在浏览器的渲染过程中(页面初始化,用户行为改变界面样式,动画改变界面样式等)reflow(回流)和repaint(重绘) 会大大影响web性能,尤其是手机页面。因此我们在页面设计的时候要尽量减少reflow和repaint。

什么是reflow和repaint(原文链接:http://www.cnblogs.com/Peng2014/p/4687218.html)

reflow:例如某个子元素样式发生改变,直接影响到了其父元素以及往上追溯很多祖先元素(包括兄弟元素),这个时候浏览器要重新去渲染这个子元素相关联的所有元素的过程称为回流。

reflow:几乎是无法避免的。现在界面上流行的一些效果,比如树状目录的折叠、展开(实质上是元素的显 示与隐藏)等,都将引起浏览器的 reflow。鼠标滑过、点击……只要这些行为引起了页面上某些元素的占位面积、定位方式、边距等属性的变化,都会引起它内部、周围甚至整个页面的重新渲 染。通常我们都无法预估浏览器到底会 reflow 哪一部分的代码,它们都彼此相互影响着。

repaint:如果只是改变某个元素的背景色、文 字颜色、边框颜色等等不影响它周围或内部布局的属性,将只会引起浏览器 repaint(重绘)。repaint 的速度明显快于 reflow

下面情况会导致reflow发生

1:改变窗口大小

2:改变文字大小

3:内容的改变,如用户在输入框中敲字

4:激活伪类,如:hover

5:操作class属性

6:脚本操作DOM

7:计算offsetWidth和offsetHeight

8:设置style属性

那么为了减少回流要注意哪些方式呢?

1:不要通过父级来改变子元素样式,最好直接改变子元素样式,改变子元素样式尽可能不要影响父元素和兄弟元素的大小和尺寸

2:尽量通过class来设计元素样式,切忌用style

var bstyle = document.body.style; // cache

bstyle.padding = "20px"// reflow, repaint

bstyle.border = "10px solid red"//  再一次的 reflow 和 repaint

bstyle.color = "blue"// repaint

bstyle.backgroundColor = "#fad"// repaint

bstyle.fontSize = "2em"// reflow, repaint

// new DOM element - reflow, repaint

document.body.appendChild(document.createTextNode('dude!'));

对上面代码优化:

.b-class{

  padding:20px;

  color:blue;

  border:10px solid red;

  background-color:#fad;

  font-size:2em;

}

$div.addClass("b-class");

3:实现元素的动画,对于经常要进行回流的组件,要抽离出来,它的position属性应当设为fixed或absolute

4:权衡速度的平滑。比如实现一个动画,以1个像素为单位移动这样最平滑,但reflow就会过于频繁,CPU很快就会被完全占用。如果以3个像素为单位移动就会好很多。

5:不要用tables布局的另一个原因就是tables中某个元素一旦触发reflow就会导致table里所有的其它元素reflow。在适合用table的场合,可以设置table-layout为auto或fixed,

6:这样可以让table一行一行的渲染,这种做法也是为了限制reflow的影响范围。

7:css里不要有表达式expression

8:减少不必要的 DOM 层级(DOM depth)。改变 DOM 树中的一级会导致所有层级的改变,上至根部,下至被改变节点的子节点。这导致大量时间耗费在执行 reflow 上面。

9:避免不必要的复杂的 CSS 选择器,尤其是后代选择器(descendant selectors),因为为了匹配选择器将耗费更多的 CPU。

10: 尽量不要过多的频繁的去增加,修改,删除元素,因为这可能会频繁的导致页面reflow,可以先把该dom节点抽离到内存中进行复杂的操作然后再display到页面上。

在div.first里面加入div.second,在div.second里面加入div.third:

$divS = $("<div class='second'></div>");

$(div.first).append($divS));//reflow

$divT = $("<div class='third'></div>");

$divS.append($divT);//reflow

优化代码:

$divS = $("<div class='second'></div>");

$divT = $("<div class='third'></div>");

$divS.append($divT);

$(div.first).append($divS));//reflow

或者:

var $divF = $(div.first);

$divS = $("<div class='second'></div>");

$divS.hide();

$(div.first).append($divS));

$divT = $("<div class='third'></div>");

$divS.append($divT);

$divS.show();//reflow

请求如下值offsetTop, offsetLeft, offsetWidth, offsetHeight,scrollTop/Left/Width/Height,clientTop/Left/Width/Height,浏览器会发生reflow,建议将他们合并到一起操作,可以减少回流的次数。

如果我们要经常去获取和操作这些值,则可以先将这些值缓存起来例如:

var windowHeight = window.innerHeight;//reflow

for(i=0;i<10;i++){

  $body.height(windowHeight++);

  一系列关于windowHeight的操作.......

}

二、添加Expires头能有效的利用浏览器的缓存能力来改善页面的性能,能在后续的页面中有效避免很多不必要的Http请求,WEB服务器使用Expires头来告诉Web客户端它可以使用一个组件的当前副本,直到指定的时间为止。

三、

参考链接:

http://ued.alimama.com/front-end/quick-tips-among-yahoo-n-rules/

http://www.cnblogs.com/Peng2014/p/4687218.html

https://www.cnblogs.com/zhutao/p/6551216.html

http://www.15wanjia.com/news/13461.html

相关文章:

  • 怎么做网站内容论坛推广工具
  • 网站制作的服务机构如何优化关键词提升相关度
  • 红色文创产品设计泰安网站优化公司
  • 个人网站可以做哪些内容网站建设开发价格
  • 集团做网站方案制作包含哪些方面深圳网站建设三把火科技
  • 静态网站做新闻系统微信推广平台哪里找
  • 编程培训机构加盟怎样北京网站快速优化排名
  • 湖南省网站建设企业培训权威机构
  • 大连企业网站哪一家好安徽网络seo
  • 网络小说网站推广策划方案外贸网站
  • 做网站用哪几个端口 比较好武汉网站关键词推广
  • 建立网站需要多少钱湖南岚鸿影视网站怎么优化关键词排名
  • 网站企业优化免费网站推广软件下载
  • 青岛做网站皆赴青岛博采网络产品推广的渠道
  • 网站建设 php东莞优化seo
  • WordPress文章设置时间免费旺道seo优化软件怎么用
  • 网站没有被搜索引擎收录竞价账户托管哪家好
  • 做网站公司深一套完整的运营方案
  • 网站建设中啥意思南昌seo排名收费
  • 企业网站免费源码邳州网站开发
  • vps用什么软件做网站河南网站推广优化排名
  • 网站建设最新签约北京seo公司司
  • 广东地区建网站的公司推广资讯
  • 有专门做试吃的网站吗广州网页seo排名
  • 做微信商城网站建设新产品推广方式有哪些
  • 龙岩网站建设设计服务站长网站统计
  • 两学一做注册网站吗精准防控高效处置
  • app扁平化设计网站模板seo美式
  • 郑州做网站优化地址网络维护公司
  • 厦门 微网站建设公司东莞seo顾问