红包雨互动小游戏的实现后的总结

如何实现全屏红包雨

冷静分析一下,无外乎就是

  1. 红包下落动画
  2. 点击红包的动画
  3. 游戏结束弹个优惠券

核心功能点就是红包的下落功能,第一反应就是。要么使用canvas、要么使用CSS3。

我采用的css3.

  • 单个红包@keyframes下落动画
  • 红包点击事件判断
  • 全部红包生成位置及下落方式
  • 扣点细节(提高用户体验)
    • 点击反馈
    • 提前加载图片
    • 优化红包点击事件

1 动画减少回流与重绘,提升动画性能

一句话:回流一定会重绘,重绘不一定会回流。

回流 (Reflow)

Render Tree中部分或全部元素的尺寸、结构、或某些属性发生改变时,浏览器重新渲染部分或全部文档的过程称为回流。

会导致回流的操作:

  • 页面首次渲染
  • 浏览器窗口大小发生改变
  • 元素尺寸或位置发生改变
  • 元素内容变化(文字数量或图片大小等等)
  • 元素字体大小变化
  • 添加或者删除可见DOM元素
  • 激活CSS伪类(例如::hover
  • 查询某些属性或调用某些方法

一些常用且会导致回流的属性和方法:

  • clientWidthclientHeightclientTopclientLeft
  • offsetWidthoffsetHeightoffsetTopoffsetLeft
  • scrollWidthscrollHeightscrollTopscrollLeft
  • scrollIntoView()scrollIntoViewIfNeeded()
  • getComputedStyle()
  • getBoundingClientRect()
  • scrollTo()

重绘 (Repaint)

当页面中元素样式的改变并不影响它在文档流中的位置时(例如:colorbackground-colorvisibility等),浏览器会将新样式赋予给元素并重新绘制它,这个过程称为重绘。

使用transform代替width, height, top, left等值的改变

根据浏览器的渲染流程,如果引起元素位置大小的改变,需要重新进行布局计算,然后重新生成位图,交给GPU渲染展示

而transform的改变不会对元素的位置大小产生改变,而是使用已经生成的位图,对它进行旋转,缩放,移动。

随机生成红包 保证随机性的同时,生成的红包位置 不能重叠

直接改top,动画期间页面的painting

css 复制代码
@keyframes redRainAn {
  0% {
    top: $top-p;
  }

  100% {
     top:calc(100vh + #{$img-height})
  }
}

修改transform,动画期间页面的painting,从图中可以看出 没有发生任何的回流和重绘

css 复制代码
@keyframes redRainAn {
  0% {
    transform: translateY(0);
  }

  100% {
    transform: translateY(calc(100vh + #{$img-height}));
  }
}

css3硬件加速(GPU加速). 比起考虑如何减少回流重绘,我们更希望不需要回流和重绘 使用css3硬件加速,可以让transform、opacity、filters这些动画不会引起回流重绘

2内存控制

组件销毁是否删除了监听器,以免内存泄露;

3图片压缩

推荐一个好用的压缩网站,保证图片清晰的同时能大幅度降低图片内存大小tinypng.com/

4 压缩后的图片上传到CDN中使用

5 将功能与业务分开,维护更加简单

如红包雨下雨动画由一个人开发,业务相关由其他同学开发

相关推荐
Predestination王瀞潞1 分钟前
5.4.1 通信->WWW万维网内容访问标准(W3C):WWW(World Wide Web)基本信息&核心设计目标&现实意义
css·网络·网络协议·html·url·www
木斯佳2 小时前
前端八股文面经大全:阿里云AI应用开发二面(2026-03-21)·面经深度解析
前端·css·人工智能·阿里云·ai·面试·vue
spencer_tseng3 小时前
secure-keyboard.js secure-keyboard.css
javascript·css
小J听不清15 小时前
CSS 外边距(margin)全解析:取值规则 + 实战用法
前端·javascript·css·html·css3
小J听不清16 小时前
CSS 边框(border)全解析:样式 / 宽度 / 颜色 / 方向取值
前端·javascript·css·html·css3
敲代码的约德尔人17 小时前
CSS 新特性完全指南:2026 年你必须掌握的 5 个新能力
css
dzj8881 天前
云朵字生成器-html
前端·css·html·云朵字
bluceli1 天前
CSS子选择器与伪类:精准控制元素样式的利器
前端·css
ssshooter1 天前
z-index:不仅仅是“谁在上面”那么简单
前端·css·面试
xixixin_1 天前
【CSS】字体大小不一致?px与vw渲染差异的底层原理与解决方案
前端·css