码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 同事问我为什么上级喊他把js实现改成css


    文章目录

    • 页面绘制流程
    • CSS3动画
      • 优点
      • 缺点
    • JS动画
      • 优点
      • 缺点
    • 总结

    本人不是专门写前端的,所以可能有不合理的地方,建议您多搜几篇博客看一下。

    页面绘制流程

    渲染流程主要有4个步骤

    1. 解析 HTML 生成DOM 树
    2. 解析 CSS 样式生成 CSSOM 树,CSSOM 树与 DOM 树结合生成 Render tree
    3. 布局 Render Tree 对每个节点进行布局处理,确定在屏幕上的位置
    4. 绘制 Render Tree,遍历渲染树将每个节点绘制出来
      在这里插入图片描述
      为了优化用户体验,渲染引擎不会等到 HTML 解析完才创建布局渲染树

    CSS3动画

    CSS3 动画也被称为补间动画,原因是只需要添加关键帧的位置,其他的未定义的帧会被自动生成

    优点

    浏览器可以对动画进行优化
    帧速不好的浏览器,CSS3 可以自然降级兼容
    代码简单,调优方向固定

    缺点

    无法精准的控制动画,无法实现一些复杂的动画

    JS动画

    JS 动画是逐帧动画,在时间帧上绘制内容,一帧一帧的,所以他的可再造性很高,几乎可以完成任何你想要的动画形式。

    但是由于逐帧动画的内容不一样,会增加制作的负担,占用比较大的资源空间。

    优点

    可控性高,可以实现炫酷高级的动画

    缺点

    逐帧动画占用比较大的资源空间

    总结

    因为我同事写的页面属于比较简单的静态页面,动画简单,所以我推荐他听上级的,改成CSS实现。

    如果是高级的动画效果,可能还是js来的好一点。

  • 相关阅读:
    ndk-c++
    Unity基础课程之物理引擎4-用于射击或者点击消除的射线检测方法
    剑指 Offer II 042. 最近请求次数-队列法
    Python 最好用的8个VS Code扩展
    Nginx超时配置
    第6章 Kafka面试题
    探索Webpack中的常见Loader
    ccpc宠物对战
    基于mqtt协议的信息推送平台系统的设计与实现
    基于Python和TensorFlow实现BERT模型应用
  • 原文地址:https://blog.csdn.net/qq_30326609/article/details/128034236
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号