Àí½âjavascript closures ±Õ°ü(¶ÁÊé±Ê¼Ç)
ʲôÊDZհü(closures):
±Õ°ü¾ÍÊÇÄÚ²¿º¯Êýͨ¹ýijÖÖ·½Ê½Ê¹Æä¿É¼û·¶Î§³¬³öÁËÆä¶¨ÒåµÄ·¶Î§,Õâ¾Í²úÉúÁËÒ»¸öÔÚÆä¶¨Ò巶ΧÄڵıհü.
ÕâÊÇÎÒÀí½âºóµÄÒ»¸ö¶¨Òå,ºÇºÇ!ºÜ»Þɬ°É!²»¹ýû¹ØÏµ,¿ÉÒÔÏÈ¿´¿´ÏÂÃæµÄ½²½â.
Ò» ÄÚ²¿º¯Êý(inner function)
javascriptÊÇÖ§³ÖÄÚ²¿º¯ÊýÉêÃ÷(inner function declaration)µÄ±à³ÌÓïÑÔ,
ÄÚ²¿º¯Êý¾ÍÊÇÔÚÁíÒ»¸öº¯ÊýµÄÄÚ²¿¶¨Òå,Èç
function outerFun(){
function innerFun(){
alert('hello');
}
}
º¯ÊýinnerFun¾ÍÊÇÄÚ²¿º¯Êý, ËüÔÚº¯ÊýouterFun·¶Î§ÄÚÊǿɼûµÄ,
Ò²¾ÍÊÇ˵innerFunº¯ÊýµÄÃüÃû¿Õ¼ä(namespace)ÊÇÔÚouterFun·¶Î§Ö®ÄÚ.
ÕýÈ·µ÷ÓÃ:
function outerFun(){
function innerFun(){
alert('hello');
}
innerFun();
}
outerFun(); //alerts "hello"
´íÎóµ÷ÓÃ(error):
function outerFun(){
function innerFun(){
alert('hello');
}
}
innerFun();
ÄÇôÈç¹ûÎÒÏëÔÚº¯ÊýouterFunÍâÃæµ÷Óú¯ÊýinnerFun,ÎÒ¸ÃÈçºÎ×öÄØ?
×ö·¨1:
var globVar;
function outerFun() {
function innerFun() {
alert('hello');
}
globVar = innerFun;
}
outerFun();
globVar();
×ö·¨2:
function outerFun() {
function innerFun() {
alert('hello');
}
return innerFun ;
}
var globVar = outerFun();
globVar();
×ö·¨3:
function outerFun() {
function innerFun() {
alert('hello');
}
return {'innerFun':innerFun} ;
}
var globVar = outerFun();
globVar.innerFun();
ÒÔÉÏÈýÖÖ×ö·¨°ÑÄÚ²¿º¯ÊýµÄ¿É¼û·¶Î§À©´óÁË, ÆäÖÐ×îºóÒ»ÖÖ×ö·¨ÊǰÑÄÚ²¿º¯Êýµ±×öÄäÃû¶ÔÏó{'innerFun':innerFun}µÄÊôÐÔ,²¢ËæÖ®Ò»Æð·µ»Ø.
´ÓÖп´µ½ÔÚjavascriptÀïÃæ,º¯ÊýÃû³Æ¿ÉÒÔµ±×÷ÊÇÒ»ÖÖÒýÓñäÁ¿,ÀàËÆÓÚcÀïÃæÖ¸ÕëµÄ¸ÅÄî,ÔÚÕâÀï,Ëæ×ųÌÐòµÄÖ´ÐÐ
»á²úÉúÁ½¸öÒýÓñäÁ¿Ö¸ÏòÄÚ²¿º¯ÊýinnerFun,Ò»¸öÊÇglobVar(µÚÈýÖÖ×ö·¨ÊÇglobVar.innerFun),ÁíÒ»¸öÊÇÆäº¯Êý×ÔÉíinnerFun,
Ö»²»¹ýÕâÁ½¸ö±äÁ¿µÄ¿É¼û·¶Î§²»Ò»Ñù,¼´ÃüÃû¿Õ¼ä²»Ò»Ñù.
javascriptÀ¬»ø»ØÊÕÆ÷»áÔÚº¯Êý×îºóÒ»¸öÒýÓñäÁ¿±»·ÏÆúºó,ÊÍ·ÅÆäËùÕ¼ÓõÄÄÚ´æ.
¶þ ±äÁ¿·¶Î§
Àý1 ÄÚ²¿º¯Êý±äÁ¿
ÔÚÄÚ
Ïà¹ØÎĵµ£º
scrollHeight: »ñÈ¡¶ÔÏóµÄ¹ö¶¯¸ß¶È¡£
scrollLeft:ÉèÖûò»ñȡλÓÚ¶ÔÏó×ó±ß½çºÍ´°¿ÚÖÐĿǰ¿É¼ûÄÚÈݵÄ×î×ó¶ËÖ®¼äµÄ¾àÀë
scrollTop:ÉèÖûò»ñȡλÓÚ¶ÔÏó×î¶¥¶ËºÍ´°¿ÚÖпɼûÄÚÈݵÄ×î¶¥¶ËÖ®¼äµÄ¾àÀë
scrollWidth:»ñÈ¡¶ÔÏóµÄ¹ö¶¯¿í¶È
offsetHeight:»ñÈ¡¶ÔÏóÏà¶ÔÓÚ°æÃæ»òÓɸ¸×ø±ê offsetParent ÊôÐÔÖ¸¶¨µÄ¸¸×ø±êµÄ¸ß¶È
offsetL ......
Ô´³ÌÐò£º
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>JavaScript×Ö·û´®ÖеÄ×Ö·ûÊý×é&l ......
event´ú±íʼþµÄ״̬£¬ÀýÈç´¥·¢event¶ÔÏóµÄÔªËØ¡¢Êó±êµÄλÖü°×´Ì¬¡¢°´ÏµļüµÈµÈ¡£
event¶ÔÏóÖ»ÔÚʼþ·¢ÉúµÄ¹ý³ÌÖвÅÓÐЧ¡£
eventµÄijЩÊôÐÔÖ»¶ÔÌØ¶¨µÄʼþÓÐÒâÒå¡£±ÈÈ磬fromElement ºÍ toElement ÊôÐÔÖ»¶Ô onmouseover ºÍ onmouseout ʼþÓÐÒâÒå¡£
Àý×Ó
ÏÂÃæµÄÀý×Ó¼ì²éÊó±êÊÇ·ñÔÚÁ´½ÓÉϵ¥»÷£¬²¢ÇÒ£¬Èç¹ûshift¼ü±»°´Ï ......
1.document.write(""); Êä³öÓï¾ä
2.JSÖеÄ×¢ÊÍΪ//
3.´«Í³µÄHTMLÎĵµË³ÐòÊÇ:document->html->(head,body)
4.Ò»¸öä¯ÀÀÆ÷´°¿ÚÖеÄDOM˳ÐòÊÇ:window->(navigator,screen,history,location,document)
5.µÃµ½±íµ¥ÖÐÔªËØµÄÃû³ÆºÍÖµ:document.getElementById("±íµ¥ÖÐÔªËØµÄIDºÅ").name(»òvalue)
6.Ò»¸öСдת´ó ......
ÔÚb/s¿ª·¢Öо³£Óõ½µÄjavaScript¼¼Êõ
Ò»¡¢ÑéÖ¤Àà
1¡¢Êý×ÖÑéÖ¤ÄÚ
1.1 ÕûÊý
1.2 ´óÓÚ0µÄÕûÊý £¨ÓÃÓÚ´«À´µÄIDµÄÑéÖ¤)
1.3 ¸ºÕûÊýµÄÑéÖ¤
1.4 ÕûÊý²»ÄÜ´óÓÚiMax
1.5 ÕûÊý²»ÄÜСÓÚiMin
2¡¢Ê±¼äÀà
2.1 ¶Ìʱ¼ä£¬ÐÎÈç (13:04:06)
2.2 ¶ÌÈÕÆÚ£¬ÐÎÈç (2003-12-05)
2.3 ³¤Ê±¼ä£¬ÐÎÈç (2003-12-05 13:04:06)
2. ......