如何解读DW下的这些代码?

jaybaijie 2008-11-19

这是在DW下实现的一个鼠标+图片事件,即鼠标经过,初始图片改变为新图片,鼠标移出显示初始图片:

<title>Event of Mouse and Picture</title>
<script type="text/JavaScript">
<!--
function MM_swapImgRestore() { //v3.0
  var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
}

function MM_preloadImages() { //v3.0
  var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
    var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
    if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}

function MM_findObj(n, d) { //v4.01
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
  if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function MM_swapImage() { //v3.0
  var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
   if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
}
//-->
</script>
</head>
<body onload="MM_preloadImages('pic/FOOTBALL.gif')">
<a href="www.google.com" onmouseout="MM_swapImgRestore()" onmouseover="MM_swapImage('Image1','','pic/FOOTBALL.gif',1)"><img src="pic/BIKE.gif" alt="C" name="Image1" width="213" height="313" border="0" id="Image1" /></a>
</body>
</html>




问题1:
为什么在显示代码里(<body>里)的MM_swapImage()方法有四个参数,但是在js的MM_swapImage()里却没有参数呢,

问题2:
一般的如果要实现这样的功能实现的代码是如何写的?(不依靠工具)

(如上代码可以运行,只需要改变一下图片的位置即可)
谢谢

 

anson_xu 2008-12-09
a=MM_swapImage.arguments就里就可以取到body里MM_swapImage传来的所有参数
Global site tag (gtag.js) - Google Analytics