之前给客户做了个网站,其中有这么一个功能:

文章内容中,有指向某个图片的链接,链接内容为图片名称(文字),点击之后在页面上弹出该图片显示,图片可以为png,jpg,gif等。

于是,祭出了JQuery与JQuery的插件们。弹出图片,用了blockUI,简单易用。

为了获取到图片的大小,借用了 http://www.planeart.cn/?p=1121  再谈javascript图片预加载技术 文中的代码

HTML中,做了最基础的链接,加上一个名为“image” 的css,用来做JQuery的选择器

<a href="image/pic01.jpg" class="image">图片1</a>

Js中如下写:

$(document).ready(function(){

     $('a.image').click(function(){
var src = $(this).attr('src');
// 之前在HTML定义了一个 #imgBox 的div作为容器
       //
  

imgReady(src,function(){
      var w = this.width ;
      var h = this.height ;
  $('#imgBox').html('').append($(this));
  $.blockUI({
    message: $('#imgBox'),
    css: {
      top: '50%',
      left: '50%',
      textAlign: 'center',
      marginLeft: '-' + (w / 2) + 'px',
      marginTop: '-' + (h / 2) + 'px',
      width: (parseInt(w) + 30) + 'px',
      height: (parseInt(h) + 30) + 'px',
      background: 'none'
    }
});

$('.blockOverlay').attr('title', '单击关闭').click($.unblockUI);

});

看起来就这么简单,用chrom和ie9测试过后,没有问题就交给了客户。可没过几天,客户反应,这些链接在IE8中点一个1,2次再点就没反应了。仔细检查代码,没发现不妥,遂找来虚拟机开始测试。

1、IE8,第一次点链接,图片很快显示,但点到几次之后,明显越来越慢,打开任务管理器,发现内存飙升很快,不会明显减少;

一个采样数据:启动:4.5MB左右,打开网页:98MB左右

点击链接弹出图片

1次:160MB,关闭后减小到128MB

2次:190MB,关闭后:159MB

3次:220MB,关闭后:189MB

后面就会一直这么上升,响应速度越来越慢..

2、Chrome,点击图片n次,都是OK的,跟了下Chrome的内存占用情况,内存也会小幅增长,但是也会恢复到之前的水平;

[我常用的是Chrome,为了测试,先用IE来编辑博客,要能够CHrome来测试。。]

打开Chrome:居然开了4个进程(xxxx),没搞懂怎么回事,打开同一个网页,然后从 任务管理器中“转到进程”,占用123MB

点击图片

#1  显示图片:转到的进程没什么变化,另外一个进程从 24MB增加到了30MB,关闭图片:30MB的进程减小都25MB

#2 显示图片:跟第一次一样,另外一个进程从24-》30MB,关闭图片,这次30MB的进程没变化

后面经过N次点击,发生变化的进程内存从30-45MB之间波动,弹出图片也很流畅

疑问:难道Chrome的JS引擎是单独一个进程?

3、IE10,使用按键精灵点击若干遍之后,内存依然平稳

IE10,打开之后,2个进程:一个13MB,一个6MB

载入网页:启动了第三个进程?(不是很明白IE10的工作模式),内存108MB

点击弹出图片

#1 内存基本没变,增加了1MB,变成了109MB,其他两个基本没变化,关闭图片:基本没变化

#2 变化依然不大

点击了几十次之后,110MB左右,几乎无波动。

------------------------------------------------------------------------------

注:测试所用的图片很小,分辨率为640*800,JPG

-----------------------------------------------------------------------------

难道IE8的JS引擎就是如此不堪?还是blockUI吃资源太严重?还是我用到的JS代码存在不合理? 还请园子里的朋友帮忙解答..

(未完待续)

IE8的 JS 引擎如此不堪?的更多相关文章

  1. IE8的 JS 引擎如此不堪(二) - 解决方案

    上一篇,IE8的JS引擎内存不停增长,是因为动态生成了一个image对象导致的.有了病因,就开始寻找治疗方法. 1.使用一个固定的img对象,但是无法获取地址改变后的图片大小,最总还是放弃: 2.寻找 ...

  2. JS引擎线程的执行过程的三个阶段(二)

    继续JS引擎线程的执行过程的三个阶段(一) 内容, 如下: 三. 执行阶段 1. 网页的线程 永远只有JS引擎线程在执行JS脚本程序,其他三个线程只负责将满足触发条件的处理函数推进事件队列,等待JS引 ...

  3. 浏览器内核、排版引擎、js引擎

    [定义] 浏览器最重要或者说核心的部分是“Rendering Engine”,可大概译为“渲染引擎”,不过我们一般习惯将之称为“浏览器内核”.负责对网页语法的解释(如标准通用标记语 言下的一个应用HT ...

  4. 【JS】js引擎执行过程

    概述 js引擎执行过程主要分为三个阶段,分别是语法分析,预编译和执行阶段,上篇文章我们介绍了语法分析和预编译阶段,那么我们先做个简单概括,如下: 语法分析: 分别对加载完成的代码块进行语法检验,语法正 ...

  5. (转载)js引擎的执行过程(二)

    概述 js引擎执行过程主要分为三个阶段,分别是语法分析,预编译和执行阶段,上篇文章我们介绍了语法分析和预编译阶段,那么我们先做个简单概括,如下: 语法分析: 分别对加载完成的代码块进行语法检验,语法正 ...

  6. 判断js引擎是javascriptCore或者v8

    来由   纯粹的无聊,一直在搜索JavaScriptCore和SpiderMonkey的一些信息,却无意中学习了如何在ios的UIWebView中判断其js解析引擎的方法: if (window.de ...

  7. 【repost】浏览器内核、渲染引擎、js引擎

    [1]定义 浏览器内核分成两部分渲染引擎和js引擎,由于js引擎越来越独立,内核就倾向于只指渲染引擎 渲染引擎是一种对HTML文档进行解析并将其显示在页面上的工具[2]常见引擎 渲染引擎: firef ...

  8. 浏览器内核、渲染引擎、js引擎

    [1]定义 浏览器内核分成两部分渲染引擎和js引擎,由于js引擎越来越独立,内核就倾向于只指渲染引擎 渲染引擎是一种对HTML文档进行解析并将其显示在页面上的工具 [2]常见引擎 渲染引擎: fire ...

  9. 【转】浏览器内核、渲染引擎、js引擎

    [1]定义 浏览器内核分成两部分渲染引擎和js引擎,由于js引擎越来越独立,内核就倾向于只指渲染引擎 渲染引擎是一种对HTML文档进行解析并将其显示在页面上的工具[2]常见引擎 渲染引擎: firef ...

随机推荐

  1. well-known file is not secure

    执行jstack pid时,提示well-known file is not secure. 原因是pid的启动用户不是当前用户,需要切换到启动用户下执行jstack即可. 可以通过如下命令来处理: ...

  2. Redis使用手册

    简介 Redis 是一个开源的使用 ANSI C 语言编写.支持网络.可基于内存亦可持久化的日志型. Key-Value数据库. Redis面向互联网的方案提供了三种形式: 1.主从 主机进行写操作, ...

  3. 【bzoj1391】[Ceoi2008]order 网络流最小割

    原文地址:http://www.cnblogs.com/GXZlegend/p/6796937.html 题目描述 有N个工作,M种机器,每种机器你可以租或者买过来. 每个工作包括若干道工序,每道工序 ...

  4. # centos7下FFmpeg环境部署记录

    # centos7下FFmpeg环境部署记录 随着视频在网站上的应用越来越多,越来越多的网站服务器需要支持视频转码,视频压缩,FFmpeg是目前最好用的网站服务器后台转码程序,应用最多.FFmpeg是 ...

  5. Codeforces Round #430 (Div. 2) Vitya and Strange Lesson

    D.Vitya and Strange Lesson(字典树) 题意: 给一个长度为\(n\)的非负整数序列,\(m\)次操作,每次先全局异或\(x\),再查询\(mex\) \(1<=n< ...

  6. [Leetcode] Length of last word 最后一个单词的长度

    Given a string s consists of upper/lower-case alphabets and empty space characters' ', return the le ...

  7. Educational Codeforces Round 55 (Rated for Div. 2):E. Increasing Frequency

    E. Increasing Frequency 题目链接:https://codeforces.com/contest/1082/problem/E 题意: 给出n个数以及一个c,现在可以对一个区间上 ...

  8. WebForm 在 Global.asax 中捕获全局异常

    /// <summary> /// 捕获全局异常 /// </summary> /// <param name="sender">sender& ...

  9. WebOS系列-了解Wekbit【邓侃】

    注:[转载请注明文章来源.保持原样] 出处:http://www.cnblogs.com/jyli/archive/2010/02/02/1660634.html  作者:李嘉昱 这是Kan老大的We ...

  10. Sequence(ST表)(洛谷P2048)

    超级钢琴 知识储备 在做这道题前,我们先要了解一下ST表(一种离线求区间最值的方法) ST表使用DP实现的,其查询复杂度为O(1). 那么我们怎么用DP实现呢?? 首先,我们设立一个状态f[i][j] ...