世界之窗论坛's Archiver

杂草 发表于 2008-1-26 01:05

[原创]提高页面中JS脚本执行效率的插件

这个插件是自动运行的,不需要显示.
但是插件本身不能定义不显示,所以只能手动在"自定义状态栏"里删除这个插件的图标

测试:
[attach]39093[/attach]

使用本插件前:
[attach]39094[/attach]

使用本插件后:
[attach]39095[/attach]




[color=blue]插嘴 by 小絮[/color]
[color=blue]这个插件可以用过滤规则来实现:[/color]
[color=blue][code] #ex#<\/head>([\r\n]+)###<script language="Javascript">/*@cc_on eval(function(props){var code=[];for(var i=0;i<props.length;i++){var prop=props;window['_'+prop]=window[prop];code.push(prop+'=_'+prop)}return 'var '+code.join(',');}('document top setInterval clearInterval setTimeout clearTimeout alert confirm prompt open close showModalDialog showModelessDialog'.split(' '))); @*/</script>$1</head>$1[/code][/color]
[i][color=blue]这样就可以不显示图标和解决刷新后无效的问题了。[/color][/i]
[color=green][/color]
[color=green]再插一嘴 by 杂草[/color]
[color=#008000]不好意思,改了一下,因为[/color][color=#008000]放在</head>之前才能起到最大作用。[/color]
[i][color=#008000]注1:用过滤规则的方法,对本地网页无效,比如D:\test.htm。[/color]
[color=#008000]注2:是不是应该捧一下我那篇“另类插件”...[/color]
[color=orange][/color][/i]
[color=orange]改进 by 杂草[/color]
[color=orange]1.原来的过滤规则会导致某些网页不能正常显示,比如QQ空间,163.com无法写邮件等......[/color]
[color=#ffa500]  在这之前用白名单方式暂时解决这条规则的冲突的,可以去掉相关的白名单了。[/color]
[color=#ffa500]2.另加一条加速背景图的规则。[/color]
[color=#ffa500]  IE对于<img>的图,会自动判断本地缓存,但是对于css中的background-image的背景图就每次都是重新下载。[/color]
[color=#ffa500][code]#ex#<\/head>([\r\n]+)###<script language="Javascript">try {document.execCommand("BackgroundImageCache", false, true);} catch(e) {}</script>$1</head>$1[/code][/color]

[[i] 本帖最后由 杂草 于 2009-2-20 21:23 编辑 [/i]]

xlez 发表于 2008-1-26 01:52

[code]eval(
    function(props)
    {
        var code = [];
        for (var i = 0; i < props.length; i++)
        {
            var prop = props;
            window['_' + prop] = window[prop];
            code.push(prop + '=_' + prop)
        }
        return 'var ' + code.join(',');
    }
    ('document self top parent setInterval clearInterval setTimeout clearTimeout alert confirm prompt open close showModalDialog showModelessDialog'.split(' '))
);[/code]上面是什么意思啊?好像绕了一圈又用 var 重命名?
theworld本来就是ie内核,为什么还要条件编译?
望高手指点。 :D
还有就是eval,直接不就完了?window['_' + prop] = window[prop];

[[i] 本帖最后由 xlez 于 2008-1-26 02:36 编辑 [/i]]

81635631 发表于 2008-1-26 02:09

此等高深好东西一定是要顶的

needed 发表于 2008-1-26 02:44

内存换效率?

ttrry 发表于 2008-1-26 11:42

其实只一行也是可以的,且经试验效果相同~
SpeedUpJS.htm中内容:
<script language="Javascript">
/*@cc_on _d=document;eval('var document=_d')@*/
</script>
听别人说可以提高JS运行速度5倍,但我在我的机器上试验可提高10倍左右~!

原理说明:
首先,IE里document就这样直接被调用的话被执行的是window 对象的内部函数,而这个比较低效的。根据这一点,下面的处理可以提高速度:
var doc = document;

document; // 慢
doc; // 这个比上面的(document)快

虽然像上面那么写可以直接使用,但是之前用到document的地方都要去替换,这个有点麻烦了点吧。所以,看下面的:
var doc = document;
var document = doc;
可以实现的话那就太好了……

了解JavaScript的人应该知道,JavaScript的变量是在最开始的时候就生成的,所以这里的document就变成了undefined了。
没关系,继续改进~
var doc = document;
eval(’var document = doc’);

eval的作用就是在作用域范围内改变变量,这样的话,后面的document就可以被正常使用了。
最后,加上只有在IE内有效的条件,就像下面这样就可以了~
/*@cc_on
var doc = document;
eval(’var document = doc’);
@*/

所以,如下面,document以外的全局变量也可以用上面的方法,起到加速的作用。
/*@cc_on
eval((function(props) {
var code = [];
for (var i = 0 l = props.length;i<l;i++){
var prop = props[i];
window[’_'+prop]=window[prop];
code.push(prop+’=_’+prop)
}
return ‘var ‘+code.join(’,');
})(’document self top parent alert setInterval clearInterval
setTimeout clearTimeout’.split(’ ‘)));
@*/

“alert confirm prompt open close showModalDialog showModelessDialog”这句对JS代码运行优化不起作用,可以去掉~

def 发表于 2008-1-26 11:52

虽然不太懂这个JS效率,但是直觉告诉我这是个好插件,顶了之后马上下下来用!:)

杂草 发表于 2008-1-26 12:05

xixi,终于有人google到这篇东西了

1.
对于var doc = document
doc是document对象的引用,而不是克隆,
所以这段代码只是占用很少量的内存.

2.
对于alert("aaa"),其实这是简写的,完整的代码是window.alert("aaa")
document.all.field1.value = "aaa"也是简写,完整的写法是window.document.all.field1.value = "aaa"
可以看到JS大量访问window对象(有一些类除外,比如Math, String, RegExp)
window这个对象太大了,访问起来很费劲,
所以把常用的window对象的属性和方法,在页面中定义一个引用型的变量,以加快调用.

3.
var document = window.document这种写法,用同名的变量覆盖window属性/方法,
不是必须的,也可以var doc = window.document
但是这种同名覆盖的写法,可以使这段代码当作外挂来使用,直接作用在原有的JS脚本上面.

4.
以上文字都是我瞎想的,因为实在无聊啊.哈哈......

杂草 发表于 2008-1-26 12:28

再给出一个例子,以加深对window对象的印象

<script>
var s;

var date = new Date;
for (var i = 0; i < 100000; i++) s = "ss";
alert(new Date - date);  //79

date = new Date;
for (var i = 0; i < 100000; i++) window.s = "tt";
alert(new Date - date);   //735

alert(s);   //tt(注意:不是ss)
</script>

81635631 发表于 2008-1-26 15:20

看了这么多.反正就是很有用咯..:shy:

wdpfox 发表于 2008-1-27 13:37

是个好插件,多谢楼主分享!:D :D

sky5 发表于 2008-1-27 15:33

在IE中据说appendchild比innerHTML要快很多倍,还有对比测试呢

Smin 发表于 2008-1-27 16:48

支持一下。。。。:wait:

AY 发表于 2008-1-28 06:11

在页面加载后才提高 js 效率没多大作用吧。 :)

杂草 发表于 2008-1-28 09:42

"页面加载"与"JS执行"是同一回事吗?
加速的是JS执行效率,不是页面下载速度.

AY 发表于 2008-1-28 11:36

回复 14# 的帖子

我的意思是在页面加载后才增加 js 效率对日常浏览网页没有太大帮助,因为大部份网页的 js 都是在页面加载时执行的,很少在页面加载后还需要执行大量 js。

我是说 "页面加载" ,并非 "页面下载" 。

[[i] 本帖最后由 AY 于 2008-1-28 11:39 编辑 [/i]]

杂草 发表于 2008-1-28 12:29

那就要看TW加载自动插件,是在onload之前还是之后.

不过TW好象一直都有个问题,就是页面刷新后,自动插件并没有再次执行.

anyway,这个插件只是玩具性质,不必太过于迷信"xx加速"这种东东.

ttrry 发表于 2008-1-28 14:26

对,页面刷新后,自动插件不会再次执行~这是个问题,我在另外一个帖就是因了考虑这个才问的

sky5 发表于 2008-1-28 20:42

杂草,请帮忙看看这段js的效率,为何当位数多或调用太频繁就CPU占用狂飙

function outnum(n,ln){
var s=n.toString().length;
if (s<ln){
var z="";
for (i=0;i<eval(ln-s);i++){z+="0";}return z+n;}
else{return n;}
}

sky5 发表于 2008-1-28 20:42

有假死现象哦,why

function outnum(n,ln){
var s=n.toString().length;
if (s<ln){
var z="";
for (i=0;i<eval(ln-s);i++){z+="0";}return z+n;}
else{return n;}
}

杂草 发表于 2008-1-30 12:12

//优化循环
function outnum1(n, ln)
{
    var sn = n.toString();
    for (var i = sn.length; i < ln; i++) sn = "0" + sn;
    return sn;
}
alert(outnum1(123, 5));

//如果是填充"0",可以用10的n次方代替n个"0"相加
function outnum2(n, ln)
{
    var sn = n.toString();
    var i = Math.max(sn.length, ln);
    sn = "" + Math.pow(10, ln) + sn;
    return sn.substring(sn.length - i);
}
alert(outnum2(123, 5));

//如果可以的话,直接用pattern,省去每次调用都要进行加"0"的运算
function outnum3(n, patt)
{
    var sn = n.toString();
    var i = Math.max(sn.length, patt.length);
    sn = patt + sn;
    return sn.substring(sn.length - i);
}
alert(outnum3(123, "00000"));

sky5 发表于 2008-1-30 12:30

这样可是试试不出来的

我自己弄了一段进制转换的js,想用格式化输出,可是非常慢,而且假死

function car(carr){
var cdrr="";
//if (!carr){cdrr='请输入数字';};
for (i=0;i<carr.length;i++){
var m=carr.charAt(i);
//var n=parseInt(m,16).toString(2);
[b]var nts=outnum(m.valueOf(),4);[/b]
cdrr+=nts+" ";
}
darr.value=cdrr;
//alert(carr);
}

[[i] 本帖最后由 sky5 于 2008-1-30 12:33 编辑 [/i]]

杂草 发表于 2008-1-30 12:41

var s;

var date = new Date;
for (var i = 0; i < 100000; i++) s = outnum1(123, 5);
alert(new Date - date);  //986

date = new Date;
for (var i = 0; i < 100000; i++) s = outnum2(123, 5);
alert(new Date - date);  //1656

date = new Date;
for (var i = 0; i < 100000; i++) s = outnum3(123, "00000");
alert(new Date - date);  //1375

我错了,看来Math.pow和String.substring也是很慢的,这也许是IE的内伤:JS引擎太慢.

而你原来的那个函数,用这种执行10万次来测速的话,根本就死机了.

[[i] 本帖最后由 杂草 于 2008-1-30 13:04 编辑 [/i]]

xlez 发表于 2008-1-30 17:47

[code]
a=5 //长度几位
s='214' //待格式化的数或字符
k=(new Array(a)).join('0').slice(s.length-a)+s
alert(k)
[/code]
欢迎你们到51js.com来讨论js问题。

needed 发表于 2008-1-30 19:00

[url]http://bbs.ioage.com/cn/viewthread.php?tid=45508&page=1&authorid=10253[/url]

页: [1] 2 3 4 5

Powered by Discuz! Archiver 7.2  © 2001-2009 Comsenz Inc.