Àí½â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 ......
Ò³Ãæ×Ô¶¯Ë¢Ð´úÂë´óÈ«£¬»ù±¾ÉÏËùÓÐÒªÇó×Ô¶¯Ë¢ÐÂÒ³ÃæµÄ´úÂë¶¼ÓУ¬´ó¼Ò¿ÉÒÔ×ÔÓÉ·¢»Ó×ö³öÍêÃÀµÄÒ³Ãæ¡£
1)
10±íʾ¼ä¸ô10ÃëË¢ÐÂÒ»´Î
2)
<script>
window.location.reload(true);
</script>
Èç¹ûÊÇÄãҪˢÐÂijһ¸öiframe¾Í°Ñwindow¸ø»»³ÉframeµÄÃû×Ö»òIDºÅ
3)
<script>
window.navigate("±¾Ò³Ãæurl"); ......
event´ú±íʼþµÄ״̬£¬ÀýÈç´¥·¢event¶ÔÏóµÄÔªËØ¡¢Êó±êµÄλÖü°×´Ì¬¡¢°´ÏµļüµÈµÈ¡£
event¶ÔÏóÖ»ÔÚʼþ·¢ÉúµÄ¹ý³ÌÖвÅÓÐЧ¡£
eventµÄijЩÊôÐÔÖ»¶ÔÌØ¶¨µÄʼþÓÐÒâÒå¡£±ÈÈ磬fromElement ºÍ toElement ÊôÐÔÖ»¶Ô onmouseover ºÍ onmouseout ʼþÓÐÒâÒå¡£
Àý×Ó
ÏÂÃæµÄÀý×Ó¼ì²éÊó±êÊÇ·ñÔÚÁ´½ÓÉϵ¥»÷£¬²¢ÇÒ£¬Èç¹ûshift¼ü±»°´Ï ......
µÚ3ÕÂ ¶ÔÏó
JavaScriptµÄ¼òµ¥ÀàÐͰüÀ¨Êý×Ö¡¢×Ö·û´®¡¢²¼¶ûÖµ£¨trueºÍfalse£©¡¢nullÖµºÍundefinedÖµ¡£ÆäËûËùÓеÄÖµ¶¼ÊǶÔÏó¡£Êý×Ö¡¢×Ö·û´®ºÍ²¼¶ûÖµ“Ã²ËÆ”¶ÔÏó£¬ÒòΪËüÃÇÓµÓз½·¨£¬µ«ËüÃÇÊDz»¿É±äµÄ¡£JavaScriptÖеĶÔÏóÊǿɱäµÄ¼ü-Öµ¼¯ºÏ(keyed collections)¡£ÔÚJavaScriptÖУ¬Êý×éÊǶÔÏ󣬺¯ÊýÊǶÔÏó£¬Õý ......
±¾²©¿Í×ªÔØÓÚ£ºhttp://www.cnblogs.com/yage/archive/2009/11/20/1607220.html
¶ÔÓÚÕýÔÚ´ÓÊ»òÕß´òËã´Óʱà³ÌµÄÈËÀ´Ëµ£¬ÃæÏò¶ÔÏóÊÇÒ»¸ö¶úÊìÄÜÏêµÄ´Ê£¬¼¸ºõÿһ¸öÈ˶¼ÄÜÁоٳöÒ»Ð©ÃæÏò¶ÔÏóµÄ±à³ÌÓïÑÔ£¬ÀýÈç
C++£¬
JAVA£¬
C#µÈµÈ¡£Æäʵ£¬ÃæÏò¶ÔÏóµÄ˼ÏëÊǶÀÁ¢ÓÚ±à³ÌÓïÑԵģ¬ÀýÈçÔÚ
C#ÖУ¬ÔÚÒ»¸ö¾²Ì¬ÀàµÄ¾² ......