【已更新】【原创】Chrome53 最新版惊现无厘头卡死 BUG!
发现问题
今天有客户向我们反馈了一个BUG:一个页面在IE、FireFox、Chrome52中能正常运行,但是在最新版的Chrome53中显示不了???
习惯性的,我们需要客户提供页面在浏览器中的HTML源代码,客户居然告诉我们说:右键打不开!!!
这就怪了,莫非写的代码导致死循环了,然后浏览器崩溃了........
首先和客户确认运行环境:
- 使用了最新版的FineUIPro v3.2.0.4
- 使用了最新版的Chrome 53.0.2785 稳定版

一切看似都是最新的,然后我们让客户在IE浏览器下取到页面的HTML源代码,开始调试
分析问题
拿到页面的HTML源代码,我们在相同的Chrome53中测试,的确浏览器卡死了。
我们的第一反应就是代码中存在死循环,但是奇怪的是为啥Chrome52没有问题呢?不管他,先调试再说
最后,代码跟踪到这里地方:

其实这就是jQuery的一个DOM节点的插入操作,但是执行完这条语句后,浏览器就卡死,没反应了。
这个代码的简化示例代码如下:
$('<div></div>').appendTo('body');
其实就是对 jQuery 的 appendTo 方法的调用,这让我们的焦点转向了 jQuery,莫非是 jQuery 对 Chrome 53 不兼容?
如果存在这么严重的问题,网络上应该早就有人遇到了。但实际上没有一个人提出类似的问题,并且我们使用的 jQuery 也是最新版:v1.12.4
为了避免 FineUIPro 的客户端 JavaScript 的影响,我们把 me._fjs_el DOM 节点的内容单独拿出来,在页面上执行:
$('<div id="Panel7" class="f-panel f-panel-viewport f-cmp ui-widget" style="margin: 5px; display: block;">'+
'<div id="Panel7_Toolbar1" class="f-toolbar f-toolbar-align-left f-panel-toolbar-top ui-widget-content f-cmp ui-widget" style="display: block;"></div>'+
'<div class="f-panel-body" style="padding: 0px; overflow: auto;">'+
'<div id="fineui_0" class="f-panel ui-widget-content f-panel-border f-cmp ui-widget f-layout-vbox-item" style="margin: 5px; display: block;"></div>'+
'</div>'+
'</div>').appendTo('body')
结果是,执行完这段代码后,浏览器直接卡死:

此时,我们来到 CPU 的占用居高不下:

莫非,是 DOM 节点有问题,比如少了闭合标签之类的,导致Chrome53解析出的问题??
仔细检查后,我们确认了 DOM 节点一切正常!!
好吧,那就来折半分析问题,先删除一部分代码,发现如下两段删除了一个 DIV 节点的代码都能正常运行:
$('<div id="Panel7" class="f-panel f-panel-viewport f-cmp ui-widget" style="margin: 5px; display: block;">'+
'<div id="Panel7_Toolbar1" class="f-toolbar f-toolbar-align-left f-panel-toolbar-top ui-widget-content f-cmp ui-widget" style="display: block;"></div>'+
'<div class="f-panel-body" style="padding: 0px; overflow: auto;">'+
'</div>'+
'</div>').appendTo('body')
$('<div id="Panel7" class="f-panel f-panel-viewport f-cmp ui-widget" style="margin: 5px; display: block;">'+
'<div class="f-panel-body" style="padding: 0px; overflow: auto;">'+
'<div id="fineui_0" class="f-panel ui-widget-content f-panel-border f-cmp ui-widget f-layout-vbox-item" style="margin: 5px; display: block;"></div>'+
'</div>'+
'</div>').appendTo('body')
无厘头,本身删除的 DIV 节点都没有任何问题。更无厘头的事情时,经过好多次尝试,我们发现把原始HTML代码中 class 属性改个字符就能正常运行了:
$('<div id="Panel7" class="f-panel f-panel-viewport f-cmp ui-widget" style="margin: 5px; display: block;">'+
'<div id="Panel7_Toolbar1" class="f-toolbar f-toolbar-align-left f-panel-toolbar-top ui-widget-content f-cmp ui-widget" style="display: block;"></div>'+
'<div class="f-panel-body" style="padding: 0px; overflow: auto;">'+
'<div id="fineui_0" class="f-panel ui-widget-content f-panel-border f-cmp ui-widget f-layout-vbox-iter" style="margin: 5px; display: block;"></div>'+
'</div>'+
'</div>').appendTo('body')

好吧!这还有啥好说的,这是Chrome53本身的BUG无疑!
小结:上面的代码可复现,如果你不信,可以自己试下。
首先随便找到一个引用了 jQuery 的页面,如果不好找,可以用我们产品的示例页面:http://fineui.com/demo_pro/
打开 Chrome53, F12 打开调试窗口,执行如下代码:
$('<div id="Panel7" class="f-panel f-panel-viewport f-cmp ui-widget" style="margin: 5px; display: block;">'+
'<div id="Panel7_Toolbar1" class="f-toolbar f-toolbar-align-left f-panel-toolbar-top ui-widget-content f-cmp ui-widget" style="display: block;"></div>'+
'<div class="f-panel-body" style="padding: 0px; overflow: auto;">'+
'<div id="fineui_0" class="f-panel ui-widget-content f-panel-border f-cmp ui-widget f-layout-vbox-item" style="margin: 5px; display: block;"></div>'+
'</div>'+
'</div>').appendTo('body')
浏览器卡死!!!
然后,重新启动 Chrome53,执行如下代码:
$('<div id="Panel7" class="f-panel f-panel-viewport f-cmp ui-widget" style="margin: 5px; display: block;">'+
'<div id="Panel7_Toolbar1" class="f-toolbar f-toolbar-align-left f-panel-toolbar-top ui-widget-content f-cmp ui-widget" style="display: block;"></div>'+
'<div class="f-panel-body" style="padding: 0px; overflow: auto;">'+
'<div id="fineui_0" class="f-panel ui-widget-content f-panel-border f-cmp ui-widget f-layout-vbox-iten" style="margin: 5px; display: block;"></div>'+
'</div>'+
'</div>').appendTo('body')
浏览器正常运行!!
解决问题
既然是 Chrome53 的BUG,就等 Chrome官方出更新版本吧....
刚下载的最新版:53.0.2785.116 仍然可重现这个问题,有兴趣的同学可以自己试下(由于google官网无法访问,可以方便的通过baidu下载)。

【更新@2016-10-08 15:20】
==========================
多谢网友 @momo314 和 @也许你面容憔悴 的提醒,经测试:v53.0.2785.113 和 v53.0.2785.116 存在BUG,v53.0.2785.143 版本解决了这个问题
同时提醒正在使用 v53.0.2785.113 和 v53.0.2785.116(2016-09-15发布) 的网友,尽快升级到最新稳定版:v53.0.2785.143(2016-09-30发布!)
根据网友的反馈,开发版 Chrome v54 依然存在此BUG,而 Chrome 55 工作正常。
希望Chrome版本帝以后发稳定版时多注意,不要在新版本中引入这个问题了........
【已更新】【原创】Chrome53 最新版惊现无厘头卡死 BUG!的更多相关文章
- 【原创】IE11惊现无厘头Crash BUG(三招搞死你的IE11,并提供可重现代码)!
前言 很多人都知道我们在做FineUI控件库,而且我们也做了超过 9 年的时间,在和浏览器无数次的交往中,也发现了多个浏览器自身的BUG,并公开出来方便大家查阅: 分享IE7一个神奇的BUG(不是封闭 ...
- 【有意思的BUG】客户端无厘头 已连网的场景初始化太慢 未连网的场景异常崩溃
客户端 已连网的场景初始化太慢 当在未连接internet的时候,打开某些APP,会比较迅速地初始化进入到主页面. 但是当我在已经连接了internet的时候,打开某些APP,有些会初始化很久!!!! ...
- [原创]反汇编之一:和Taskmgr过不去篇(无厘头版)
原文链接:和Taskmgr过不去篇(无厘头版) Hook入门级文章,主要想培养一下偶写文章的感觉,老鸟无视…我想看看技术文章能不能无厘头的写,如果效果不错的话,准备更上一层-----用我的原创漫画表达 ...
- 【知识整理】惊现RecyclerView内部Bug???别急,我们慢慢解决它~
一.写在前面 这也是久违的一整个月没有写Blog,也是由于近期给妹纸找工作,各种坑蒙拐骗,然而都没卵用.额,广大朋友们,成都需要软件测试.线上运维.产品助理的伙伴,赶紧私聊我了.这妹纸,学习能力挺好, ...
- 微信快速开发框架(九)-- V3.0发布,代码已更新至Github 新增微店功能
版本内容 1.修正了缺少对Event.View的支持 2.增加了用户UnionID 3.新增微信小店功能 4.多客服功能 5.单元测试 什么是UnionID 我们知道,每个用户针对一个微信公众账号都有 ...
- 微信快速开发框架(六)-- 微信快速开发框架(WXPP QuickFramework)V2.0版本上线--源码已更新至github
4月28日,已增加多媒体上传及下载API,对应MediaUploadRequest和MediaGetRequest ------------------------------------------ ...
- 微信快速开发框架(七)--发送客服信息,版本更新至V2.2 代码已更新至github
在V2版本发布的博文中,已经介绍了大多数Api的用法,同时也收到了很多意见,其中发布了几个修正版本,修改了几个bug,在此感谢大家的使用,有了大家的支持,相信快速开发框架会越来越好,也会越来越完善的. ...
- 岁末年初3Q大战惊现高潮,360震撼推出Android "3Q" IM即时通讯
岁末年初3Q大战惊现高潮,360震撼推出Android "3Q" IM即时通讯 看过了QQ和360斗争的开端高潮,当然现在还不能说这场斗争已经结束,在我看来这次的事件未尝不是一个适 ...
- 目录 of 2013-2014-1(内容已更新结束)
(内容已更新结束) UML部分: ---------------1.概述2.用例图3.类图4.顺序图 MVC部分: ----------------1.概述2.路由3.控制器4.视图5.模型6.安装部 ...
随机推荐
- WIN7下查看CPU核心数
方法一 WIN+R输入cmd,输入wmic,输入cpu get *(注意空格),找到numberofcores和numberoflogicalprocessors,如下图为双核4线程,真核心数是2,使 ...
- 在DevExpress程序中使用TeeList控件以及节点查询的处理
在很多情况下,我们需要通过树列表进行数据的展示,如一些有层次关系的数据,通过有层级的展示,能够使用户更加直观查看和管理相关的数据.在一般Winform开发的情况下,可以使用微软的TreeView控件, ...
- CentOS 7 下安装redis步骤
1. 从redis官网下载redis源码,本例安装在/usr/opt下 [root@localhost opt]# pwd /usr/opt [root@localhost opt]# wget ht ...
- jdk顺序表笔记
一.AbstractCollection 提供了集合的最大实现 继承该类,必须实现size()和iterator(),因为该类操作集合都是通过iterator 二.fail-fast策略 该策略在集合 ...
- Css3新特性应用之形状
一.自适应椭圆 * border-radius特性: * 可以单独指定水平和垂直半径,并且值可以是百分比,用/(斜杠)分隔这两个值即可(可以实现自适应宽度椭圆). * 还可以单独指定四个角 ...
- CALayer的transform属性
先来与View比较一下 View:transform -> CGAffineTransformRotate... layer:transform -> CATransform3DRotat ...
- Android InputType详解
android:inputType 如果设置android:inputType = "number",则默认弹出的输入键盘为数字键盘,且输入的内容只能为数字. InputType文 ...
- ViewPager之Fragment页面切换
一.概述 ViewPager是android-support-v4中提供的类,它是一个容器类,常用于页面之间的切换. 继上篇文章<ViewPager之引导页>之后,本文主要介绍ViewPa ...
- js继承方式
1.原型链 实现的本质是重写原型对象,代之以一个新类型的实例: 给原型添加方法的代码硬顶放在替换原型的语句之后: 不能使用对象字面量查收能见原型方法,这样会重写原型链. 缺点:包含引用类型值的原型属性 ...
- 人工智能AI-机器视觉CV-数据挖掘DM-机器学习ML-神经网络-[资料集合贴]
说明:这个贴用于收集笔者能力范围内收集收藏并认为有用的资料,方便各方参考,免去到处找寻之苦,提升信息的交叉引用价值.仅供参考,不作为必然的推荐倾向.如涉及版权等问题请相关人员联系笔者,谢谢. |博客| ...