运行这个程序!进来看看

homerocker 2001-12-28 04:06:53
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>

<BODY>
<script language="JavaScript1.2">
//图片的链接地址
var snowsrc="图象名称.gif"
//图片的运动时间
var no = 10;
var ns4up = (document.layers) ? 1 : 0; // browser sniffer
var ie4up = (document.all) ? 1 : 0;
var dx, xp, yp; // coordinate and position variables
var am, stx, sty; // amplitude and step variables
var i, doc_width = 800, doc_height = 600;
if (ns4up) {
doc_width = self.innerWidth;
doc_height = self.innerHeight;
} else if (ie4up) {
doc_width = document.body.clientWidth;
doc_height = document.body.clientHeight;
}
dx = new Array();
xp = new Array();
yp = new Array();
am = new Array();
stx = new Array();
sty = new Array();
for (i = 0; i < no; ++ i) {
dx[i] = 0; // 图片的运行轨道
xp[i] = Math.random()*(doc_width-50); // 图片的运行轨道
yp[i] = Math.random()*doc_height;
am[i] = Math.random()*20;// 图片的运行轨道
stx[i] = 0.02 + Math.random()/10; // 图片的运行轨道
sty[i] = 0.7 + Math.random();// 图片的运行轨道
if (ns4up) { // 图片的运行轨道
if (i == 0) {
document.write("<layer name=\"dot"+ i +"\" left=\"15\" top=\"15\" visibility=\"show\"><a href=\"http://dynamicdrive.com/\"><img src='"+snowsrc+"' border=\"0\"></a></layer>");
} else {
document.write("<layer name=\"dot"+ i +"\" left=\"15\" top=\"15\" visibility=\"show\"><img src='"+snowsrc+"' border=\"0\"></layer>");
}
} else if (ie4up) {
if (i == 0) {
document.write("<div id=\"dot"+ i +"\" style=\"POSITION: absolute; Z-INDEX: "+ i +"; VISIBILITY: visible; TOP: 15px; LEFT: 15px;\"><a href=\"http://dynamicdrive.com\"><img src='"+snowsrc+"' border=\"0\"></a></div>");
} else {
document.write("<div id=\"dot"+ i +"\" style=\"POSITION: absolute; Z-INDEX: "+ i +"; VISIBILITY: visible; TOP: 15px; LEFT: 15px;\"><img src='"+snowsrc+"' border=\"0\"></div>");
}
}
}
function snowNS() { // Netscape main animation function
for (i = 0; i < no; ++ i) { // iterate for every dot
yp[i] += sty[i];
if (yp[i] > doc_height-50) {
xp[i] = Math.random()*(doc_width-am[i]-30);
yp[i] = 0;
stx[i] = 0.02 + Math.random()/10;
sty[i] = 0.7 + Math.random();
doc_width = self.innerWidth;
doc_height = self.innerHeight;
}
dx[i] += stx[i];
document.layers["dot"+i].top = yp[i];
document.layers["dot"+i].left = xp[i] + am[i]*Math.sin(dx[i]);
}
setTimeout("snowNS()", 10);
}
function snowIE() { // IE main animation function
for (i = 0; i < no; ++ i) { // iterate for every dot
yp[i] += sty[i];
if (yp[i] > doc_height-50) {
xp[i] = Math.random()*(doc_width-am[i]-30);
yp[i] = 0;
stx[i] = 0.02 + Math.random()/10;
sty[i] = 0.7 + Math.random();
doc_width = document.body.clientWidth;
doc_height = document.body.clientHeight;
}
dx[i] += stx[i];
document.all["dot"+i].style.pixelTop = yp[i];
document.all["dot"+i].style.pixelLeft = xp[i] + am[i]*Math.cos(dx[i]);
}
setTimeout("snowIE()", 40);
}
if (ns4up) {
snowNS();
} else if (ie4up) {
snowIE();
}
</script>
</BODY>
</HTML>

运行这个程序后,CPU的使用率为100%
而关掉它以后,CPU的使用率变得很小很小,接近于0,请问是为什么,有什么办法解决
...全文
132 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
okeyes 2001-12-28
  • 打赏
  • 举报
回复
在我的机器中,没有图片时小于50%,有图片时,在65%左右。
zarz 2001-12-28
  • 打赏
  • 举报
回复
silentlamb(silent)说的很对,将
setTimeout("snowIE()", 40);
setTimeout("snowNS()", 10);
后面的数值调大一些会减少资源的占用,不过‘雪花’飘的也慢了。
或者将变量no调小一点(no就是雪花的数目)也可以——100个雪花我的机器就有点累了。

没有Javascript和JavaApplet或flash的网页大家都可能已经不满意了,不能因为个别就否认它们的必要性。
blues-star 2001-12-28
  • 打赏
  • 举报
回复
是你机器烂吧,我机器还没过50%

这种程序就是这样的,也许我的是没有显示图片的原因,js程序也是需要资源的,特别是移动图片的时候,用同样的间隔一个setTimeout(第二个参数相同)移动,移一个和移十个速度明显不同的
bihu 2001-12-28
  • 打赏
  • 举报
回复
很难解决
我就很少用js,太废资源了
vincentmax 2001-12-28
  • 打赏
  • 举报
回复
拜托,别动不动就是一大段程序拿出来要人帮你找错好不好?
homerocker 2001-12-28
  • 打赏
  • 举报
回复
请问是不是死循环造成的
silentlamb 2001-12-28
  • 打赏
  • 举报
回复
把那几个setTimeout()里的时间间隔改大一点应该会好一点

87,994

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧