javascript - 解决 javascript/dom 渲染问题的更有效方法?

标签 javascript html css dom html-rendering

提前为冗长的解释道歉。我觉得这个素描最好! :P

假设我有 10 个 div,它们绝对 (css) 定位在彼此之上。每个 div 包含几个透明的 png,它们也彼此叠加,共同形成一个视觉整体。我当时只显示 1 个 div,用户可以通过单击箭头或按钮切换到下一个 div。这个箭头/按钮包含一个标签,它告诉我下一个要显示的 div,所以通过 javascript 我隐藏了所有的 div,然后立即显示合适的 div。

为什么这在大多数浏览器中都很慢?有没有更好的方法来做这样的事情? IE 和 Firefox 似乎可以相当快速和流畅地切换 div,而 Chrome 显示延迟。以下是 html 和 javascript 的概述:

HTML:

            <div id="div1" class="active generic">
                <img src="sample00.png" width="1000" height="564" class="a1" />
                <img src="sample01.png" width="1000" height="564" class="a2" />
                <img src="sample02.png" width="1000" height="564" class="a3" />
                <img src="sample03.png" width="1000" height="564" class="a4" />
                <img src="sample04.png" width="1000" height="564" class="a5" />
            </div>
            <div id="div2" class="generic">
                <img src="sample05.png" width="1000" height="564" class="a1" />
                <img src="sample06.png" width="1000" height="564" class="a2" />
                <img src="sample07.png" width="1000" height="564" class="a3" />
                <img src="sample08.png" width="1000" height="564" class="a4" />
                <img src="sample09.png" width="1000" height="564" class="a5" />
            </div>

等等……

Javascript:

a++;
var gen = $('.generic');
var div = $('#div' + a);
gen.hide().removeClass('activeFrame');
div.show().addClass('activeFrame');

任何人都无法提供更好的解决方案,这可能太模糊了。但是如果有人可以向我解释为什么这在某些浏览器/低端系统上会很慢以及我如何能够解决这个问题,我可以利用这些知识自己思考一些事情(或者接受它就是这样) .

最佳答案

关于javascript - 解决 javascript/dom 渲染问题的更有效方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12971964/

相关文章:

javascript - 将子组件的输出发送到父组件 - Angular 2

javascript - node.js - 无法使用 Sequelize 连接到 MYSQL 数据库

javascript - Vuejs动态创建元素添加鼠标事件

javascript - 复选框和本地存储

html - 如何更改 div 标签内段落标签的字体大小?

jquery - 如何使用 jquery 将 jquery ui 选项卡的位置与另一个 ui 选项卡交换?

javascript - 自动中断文本,用户名背后的理由?

html - 在 iOS 中显示不同大小的输入字段

css - 我该怎么做文本溢出 : ellipsis on two lines?

css - wordpress 中的样式菜单