• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > HTML5游戏开发 之 循环的控制(3)

HTML5游戏开发 之 循环的控制(3)

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含HTML5,游戏开发,循环等相关知识,匿名希望在学习及工作中可以帮助到您
7) 改进性能

RequestAnimationFrame确实是实现动画不可或缺的利器,但是不可以过度的使用。尤其是和一些渐变性的事件相关联的动画,比如,Chrome Web Store首页利用垂直滚轴不断显示页面内容。下面给出一个不太好的例子:

  1. function onScroll() {
    update();
    }
function update() {
// assume domElements has been declared
// by this point :)
for(var i = 0; i < domElements.length; i++) {
// read offset of DOM elements
// to determine visibility - a reflow
// then apply some CSS classes
// to the visible items - a repaint
}
}
  1. window.addEventListener(‘scroll’, onScroll, false);

上面这个例子,每次scroll事件的时候,都调用RequestAnimationFrame,虽然浏览器会量力而行的执行动画渲染,但是有两个冲突的地方,成为了动画渲染的性能瓶颈。首先,scroll事件调用的频率,远远大约每秒60帧。也就是说,浏览器会缓存大量的RequestAnimationFrame事件,导致很多的update函在做无用功。其次,在每次执行RequestAnimationFrame的时候,里面对dom元素的属性进行了修改,引起了很多的Reflow和Repaint事件,显然完成所有的Reflow和Repaint时间的远远超过16ms。

为了解决第一个问题,首先要将scroll和RequestAnimaitonFrame函数分离,修改后的代码如下:

var latestKnownScrollY = 0;
function onScroll() {
latestKnownScrollY = window.scrollY;
}
function update() {
  requestAnimationFrame(update);
  var currentScrollY = latestKnownScrollY;
  // read offset of DOM elements
  // and compare to the currentScrollY value
  // then apply some CSS classes
  // to the visible items
}
// kick off
requestAnimationFrame(update);


上面的代码,scroll事件仅负责将最新的窗口位置,赋值给一个变量。这样的话,可以避免大量的RequestAnimationFrame事件被缓存,从而真正让RequestAnimationFrame按照浏览器的能力,进行动画渲染。

对于第二个问题,唯一的办法,尽量的减少Repaint和Reflow的事件。道理虽然简单,但是优化难度很大,要求读者对于Dom的渲染的每个函数都非常熟悉。下面列出几篇文章,仅供参考:

ClassList for great good.

Breakdown of repaint.

Learning from Twitter

(未完待续)


以上就是HTML5游戏开发 之 循环的控制(3)的内容,更多相关内容请关注微课江湖()!

您可能想查找下面的文章:

  • HTML5知识点总结
  • HTML5的本地存储
  • HTML5本地存储之IndexedDB
  • Html5实现文件异步上传功能
  • Html5新标签datalist实现输入框与后台数据库数据的动态匹配
  • 详解HTML5 window.postMessage与跨域
  • HTML5拖放API实现拖放排序的实例代码
  • 解决html5中video标签无法播放mp4问题的办法
  • HTML5新特性 多线程(Worker SharedWorker)
  • Html5新增标签有哪些

相关文章

  • 2017-08-06HTML5 与 XHTML2
  • 2018-12-03突破canvas语法限制 让他支持链式语法_html5教程技巧
  • 2018-12-03HTML5 Canvas像素处理常用接口
  • 2018-12-03html5 canvas粒子形成下雪背景的效果
  • 2017-08-06详解HTML5中的拖放事件(Drag 和 drop)
  • 2018-12-03html5 学习简单的拾色器 _html5教程技巧
  • 2018-12-03HTML5Canvas save如何保存恢复状态?
  • 2018-12-03HTML5画布下js的文字云/标签云效果-D3 Cloud
  • 2018-12-03HTML5 canvas基本绘图之绘制五角星
  • 2018-12-03 小强的HTML5移动开发之路(1)——HTML介绍

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 基于html5 canvas实现漫天飞雪效果实例
    • 移动端利用H5实现压缩图片上传的功能
    • input file上传文件样式支持html5的浏览器解决方案_html5教程技巧
    • html5如何制作一份邀请函?制作邀请函的方法(代码示例)
    • HTML5 canvas基本绘图之绘制矩形的示例代码详解
    • html5 学习简单的拾色器 _html5教程技巧
    • H5的语义化标签新特性应该如何使用
    • 不可轻视HTML5!App三年内将被html5顶替彻底消失_html5教程技巧
    • 整理HTML5中表单的常用属性及新属性_html5教程技巧
    • 如何让HTML5实现移动端复制功能

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有