<Html> 
<HEAD> 
<script language="javascript"> 
function initpage() 
{ 
  window.setTimeout("window.location.reload()", 500, "Javascript"); 
} 
</script> 
</HEAD> 
<body onload="initpage()" > 
<div class='menu' id='menu'></div> 
<script language='javascript'> 
hookup(document.getElementById('menu')); 
function hookup(element) 
{ 
  element.attachEvent( "onmouSEOver", mouse); 
  function mouse () 
  {} 
} 
</script> 
</body> 
</HTML> 
In this code, the handler (the mouse function) is nested inside the attacher (the hookup function). This arrangement means that the handler is closed over the scope of the caller (this arrangement is named a "closure"). 

<html> 
<head> 
<script language="JScript"> 
function AttachEvents(element) 
{ 
  // This strUCture causes element to ref ClickEventHandler 
  element.attachEvent("onclick", ClickEventHandler); 
  function ClickEventHandler() 
  { 
   // This closure refs element 
  } 
} 
function SetupLeak() 
{ 
  // The leak happens all at once 
  AttachEvents(document.getElementById("LeakedDiv")); 
} 
function BreakLeak() 
{} 
</script> 
</head> 
<body onload="SetupLeak()" onunload="BreakLeak()"> 
<div id="LeakedDiv"></div> 
</body> 
</html> <html> 
<head> 
<script language="JScript"> 
function AttachEvents(element) 
{ 
  // In order to remove this we need to put 
  // it somewhere. Creates another ref 
  element.expandoClick = ClickEventHandler; 
  // This structure causes element to ref ClickEventHandler 
  element.attachEvent("onclick", element.expandoClick); 
  function ClickEventHandler() 
  { 
   // This closure refs element 
  } 
} 
function SetupLeak() 
{ 
  // The leak happens all at once 
  AttachEvents(document.getElementById("LeakedDiv")); 
} 
function BreakLeak() 
{ 
  document.getElementById("LeakedDiv").detachEvent("onclick", 
  document.getElementById("LeakedDiv").expandoClick); 
  document.getElementById("LeakedDiv").expandoClick = null; 
} 
</script> 
</head> 
<body onload="SetupLeak()" onunload="BreakLeak()"> 
<div id="LeakedDiv"></div> 
</body> 
</html> 新聞熱點
疑難解答