?
JavascriptÖ´ÐÐʱµÄ×¼±¸¹¤×÷£º
µ±JSÒýÇæ½øÈëÒ»¸öÖ´Ðл·¾³£¬×¼±¸Ö´ÐиÃÇøÓòµÄ´úÂëʱ£¬ÈçϹ¤×÷ÒѾÍê³É£º(1) ±äÁ¿µÄʵÀý»¯£¬(2) ×÷ÓÃÓòÁ´µÄ´´½¨ºÍ³õʼ»¯£¬(3) thisÖ¸ÕëËùÖ¸ÏòµÄÄ¿±ê¶ÔÏóµÄÈ·¶¨¡£
?
1¡¢Ö´Ðл·¾³£¨Execution Contexts£©
Ò»¶Î¿ÉÖ´ÐеÄJS´úÂ뼴Ϊһ¸öÖ´Ðл·¾³£¬·ÖΪÈýÀࣺ
1.1 È«¾Ö´úÂ룻ȫ¾Ö´úÂëÊDz»°üº¬Èκκ¯ÊýÌåµÄ´úÂ루¿ÉÒÔÓк¯Êýµ÷Óã©£»
1.2 Eval´úÂ룻evalÊÇJSÖеÄÒ»¸öÄÚÖú¯Êý£¬evalµÄ²ÎÊý¼´È«¾Ö´úÂ룻
1.3 º¯Êý´úÂ룻º¯Êý´úÂëÊǺ¯ÊýÌåÖеÄÒ»²¿·Ö´úÂ룬Õⲿ·Ö´úÂ벻ǶÌ×°üÀ¨Èκκ¯ÊýÌå´úÂë¡£×¢Òânew Function(argList)×îºóÒ»¸ö²ÎÊýÒ²Êǵ±×÷º¯Êý´úÂë´¦Àí¡£
?
?
2¡¢±äÁ¿ÊµÀý»¯£¨Variable Instantiation?£©
?
JSµÄÿ¸öÖ´Ðл·¾³£¨Ò²½ÐÖ´ÐÐÉÏÏÂÎÄ£©¶¼¹ØÁªµ½Ò»¸ö±äÁ¿¶ÔÏó£¨variable object£©¡£±äÁ¿ÊµÀý»¯½«×öÒÔÏÂÊÂÇ飺
2.1 ?Èç¹û¸ÃÖ´Ðл·¾³ÊǺ¯Êý´úÂëµÄÖ´Ðл·¾³£¬Ã¿Ò»¸öÐβÎ×÷ΪÊôÐÔÌí¼Óµ½±äÁ¿¶ÔÏóÖУ¬ÊôÐÔÃûΪÐβÎÃû£¬ÖµÊǵ÷Óøú¯ÊýʱËùÌṩµÄʵ²ÎµÄÖµ¡£Èç¹ûʵ²ÎÉÙÓÚÐβΣ¬Ôò¶à³öµÄÐβθ³ÖµÎªundefined¡£Èç¹ûÓÐÐβÎÖÐÓÐÁ½¸ö»òÕßÁ½¸öÒÔÉϵIJÎÊýµÄÃû×ÖÏàͬ£¬Ôò×îºóÒ»¸öÐβεÄÖµÊDZäÁ¿¶ÔÏóÖиÃÐβεÄÖµ£¬¼´Ê¹×îºóÒ»¸öÐβÎΪundefined¡£
?
?
2.2 ?°Ñº¯Êý¶¨Òåʽ¶¨ÒåµÄº¯Êý£¨²»ÊǺ¯Êý±í´ïʽ¶¨ÒåµÄº¯Êý£©×÷ΪÊôÐÔÌí¼Óµ½±äÁ¿¶ÔÏóÖС£ÊôÐÔÃûΪº¯ÊýÃû£¬ÖµÎªÍ¨¹ýnew Function(²ÎÊýÁбí) ´´½¨µÄÒ»¸öº¯Êý¶ÔÏ󣬸öÔÏóµÄÊôÐÔÓÉ´úÂë¾ö¶¨£¨Ö´ÐеÄʱºòÈ·¶¨£©¡£Èç¹û±äÁ¿¶ÔÏóÖÐÒѾ´æÔÚ¸ÃÃû×ÖµÄÊôÐÔ£¬ÔòÓÃеÄÖµºÍÊôÐÔÌæ»»¾ÉµÄÖµºÍÊôÐÔ¡£
?? Èç¹ûÖ´Ðл·¾³ÊǺ¯Êý´úÂ룬±ØÐëÏȳõʼ»¯º¯ÊýµÄÐβÎÁÐ±í£¬È»ºóÔÙ´¦Àí¸Ã²½Öè¡£
?
?
2.3 °Ñͨ¹ý¹Ø¼ü×Övar¶¨ÒåµÄ±äÁ¿£¨¸Ã±äÁ¿Ò²¿ÉÒÔÊÇÔ´Âëij¸öÓï¾ä¿éÖж¨ÒåµÄ£¬È磺forÓï¾äÑ»·ÌåÖж¨ÒåµÄ£©×÷ΪÊôÐÔÌí¼Óµ½±äÁ¿¶ÔÏóÖУ¬ÊôÐÔÃûΪ±äÁ¿Ãû£¬ÖµÎªundefined£¬ÖµµÄÊôÐÔÓÉ´úÂëÈ·¶¨£¨Ö´ÐеÄʱºòÈ·¶¨£©£»Èç¹û¸Ã±äÁ¿ÃûºÍº¯Êý¶¨Òå»òÕßÐβÎÖØºÏ£¬Ôò²»±÷Æú±äÁ¿¶ÔÏóÖиÃÊôÐÔµÄÒÑÓÐÊôÐÔ¡£
?? ? ?ÓïÒåÉÏ£¬±ØÐëÏȳõʼ»¯º¯ÊýÐβÎÁбíºÍº¯Êý¶¨Ò壬ÔÙ´¦Àí¸Ã²½Öè¡£
?
?
?
ʵÑé1(»·¾³Chrome 8 )£º
<script language="javascript"> var fun; function fun(a, b, a){ alert(a); } fun(1, 2, 3);//µ¯³ö£º3 fun(1, 2);//µ¯³ö£ºundefined var fun = 'not function'; fun(1);//³ö´í </script>
?
?
3¡¢×÷ÓÃÓòÁ´£¨Scope Chain£©ºÍ±äÁ¿Ê¶±ð£¨Identifier Resolution£©
ÿ¸öÖ´Ðл·¾³¶¼ÓëÒ»¸ö×÷ÓÃÓòÁ´¹ØÁª¡£×÷ÓÃÓòÁ´ÊÇÒ»¸ö¶ÔÏóÁÐ±í£¬Ö÷ÒªÓÃÓÚ±äÁ¿Ê¶±ð£¨¿ÉÒÔÀí½âΪËüÓɸ³ÖµºóµÄ±äÁ¿¶ÔÏóÒÔÁ´±íµÄÐÎʽ¹¹³É£©¡£ÏµÍ³°´ÕÕÒÔϲ½ÖèÀ´¼ÆËãÒ»¸ö±äÁ¿ vµÄÖµ£º
4¡¢È«¾Ö±äÁ¿£¨global object£©
?
?
?
5¡¢»î¶¯¶ÔÏó(activation object)
µ±JSÖ´ÐÐÒýÇæÌø×ªµ½Ò»¸öº¯Êý´úÂëÖ´Ðл·¾³Ê±£¬½«´´½¨Ò»¸ö»î¶¯¶ÔÏóÓëÖ´Ðл·¾³¹ØÁª£¬»î¶¯¶ÔÏó½«ÓµÓÐÒ»¸öÃûΪargumentsµÄÊôÐÔ£¬ÆäֵΪ´æ·Åº¯Êý²ÎÊýµÄÒ»¸öarguments¶ÔÏ󡣸û¶ÔÏó½«×÷ΪִÐк¯Êý´úÂëµÄ±äÁ¿¶ÔÏó¡£
?
´ËʱµÄ»î¶¯¶ÔÏó±»µ±×÷±äÁ¿¶ÔÏóÀ´Ö´ÐбäÁ¿ÊµÀý»¯¡£
?
»î¶¯¶ÔÏóÊÇÒ»ÖÖÌØÊâµÄʵÏÖ»úÖÆ£¬JS³ÌÐòÖ»ÄÜ·ÃÎʻ¶ÔÏóµÄ³ÉÔ±£¬²»ÄÜ·ÃÎʻ¶ÔÏó±¾Éí¡£
6¡¢arguments¶ÔÏó(Arguments object)
?
?
µ±JSÌø×ªµ½º¯Êý´úÂëÖ´Ðл·¾³Ê±£¬½«´´½¨Ò»¸öarguments¶ÔÏ󣬸öÔÏóÓÐÈçÏÂÌØµã£º
(1) arguments¶ÔÏóµÄprototypeÔÐÍΪObject¶ÔÏóµÄÔÐͶÔÏ󣬸ÃÔÐͶÔÏóµÄֵΪ¼´Object.prototype£»
(2) argumentsÓÐÒ»¸öcalleeÊôÐÔ£¬Æä³õʼֵΪ±»Ö´Ðеĺ¯Êý¶ÔÓ¦µÄº¯Êý¶ÔÏ󣨼´º¯Êý×ÔÉí£©£¬¸ÃÌØÐÔʹµÃÄäÃûº¯ÊýÒ²¿ÉÒԵݹéµ÷Óá£
(3) argumentsÓÐÒ»¸ölengthÊôÐÔ£¬ÓÃÀ´¸æËßʵ²ÎµÄ¸öÊý£»
(4) ¶ÔÓÚʵ²Î½«ÒÀ´Î·ÅÈëarguments[0], arguments[1], ?... ?, arguments[n]£»
?
?
ͼ£ºÊµÑé1ÖеÚÒ»´ÎÖ´Ðк¯Êýfunʱarguments¶ÔÏóÊôÐÔ
?
?
?
?
?
?
?
?
7¡¢Ô¤±àÒ루Ԥ´¦Àí£©
8¡¢´úÂëµÄÖ´ÐÐ
?
??Step 1£º ´´½¨×÷ÓÃÓòÁ´£¬´ËʱµÄ×÷ÓÃÓòÁ´ÖнöÓÐÒ»¸ö¶ÔÏóÈ«¾ÖµÄwindow¶ÔÏó£»
8.2 º¯Êý´úÂëµÄÖ´ÐÐ
?
8.3 Eval´úÂëµÄÖ´ÐÐ
?
´úÂë·ÖÎöÒ»
?
<script> var var1; var2 = 'var2'; fun1(); function fun1(){ alert('fun1'); var3 = 'var3'; } var var4 = function(){ alert('ÄäÃûº¯Êý'); }; var var5 = function fun2(){ alert('fun2'); }; for(var i=0; i<10; i++){ var var6 = i*i; } var var6; var5(); fun3(); var4(); </script> <script> var var7; fun3(); function fun3(){ alert('fun3'); } </script>?
- i, fun1, var1,?var4, var6¶¼×÷ΪÊôÐÔÌí¼Óµ½±äÁ¿¶ÔÏówindowÖС£ÆäÖÐfun1µÄֵΪһ¸öFunction¶ÔÏ󣬯äËü±äÁ¿µÄÖµ¶¼ÊÇundefined¡£
- ±äÁ¿iÊÇÔÚforÓï¾ä½á¹¹Öж¨ÒåµÄ£¬ var6ÊÇÔÚforÓï¾äÑ»·ÌåÖж¨ÒåµÄ£¬´Ëʱ¶¼ÒÑÌí¼Ó£»
- var7£¬ fun3²¢Ã»ÓÐÌí¼Ó£¬ÒòΪËüÔÚÁíÍâÒ»¸öscript±êÇ©ÖУ¬var2ҲûÓÐÌí¼Ó£¬ÒòΪËüûÓÐͨ¹ý¹Ø¼ü×Ö var À´¶¨Òå
- var4¶ÔÓ¦µÄÄäÃûº¯Êý±í´ïʽºÍvar5¶ÔÓ¦µÄÓÐÃûº¯Êý±í´ïʽ¶¼Ã»ÓÐÌí¼Óµ½windowÖУ¬ÒòΪËüÃÇÊǺ¯Êý±í´ïʽ£¬Ö´ÐеÄʱºò²Å½øÐмÆËã¡£var4ºÍvar5µÄֵΪundefined£¬¶øfun1µÄÖµ²»ÊÇundefined£»
- ×÷ÓÃÓòÁ´Îª: [window]
(2) Ö´ÐеÚ3ÐÐʱ£¬ÒòΪ³ÌÐò¶ÔÒ»¸öûÓж¨ÒåµÄ±äÁ¿var2¸³Öµ£¬ÏµÍ³½«ÒþʽµÄ¶¨ÒåÒ»¸ö±äÁ¿var2£¬²¢×÷ΪÊôÐÔÌí¼Óµ½windowÖУ»µÚ3ÐÐÖ´ÐнáÊøºówindow.var1 = 'undefined'; window.var2 = 'var2';
?
(3)Ö´ÐеÚ4ÐÐʱ£¬½«ÔÚµ±Ç°×÷ÓÃÓòÁ´ÖУ¬½øÐÐÒ»´Î±äÁ¿Ê¶±ð£¬ÔÚ±äÁ¿¶ÔÏówindow.fun1ÖÐÕÒµ½ÁËfun1µÄÖµ£¬²¢Ö´ÐÐfun1¡£
?
(4) µÚ9ÐÐÖ´ÐÐÍêºó£¬window.var4µÄֵΪ£ºÍ¨¹ýÄäÃûº¯Êý±í´ïʽ´´½¨µÄÒ»¸öFunction¶ÔÏó¡£
?
(5) Ö´ÐеÚ13Ðкówindow.var5µÄֵΪ£ºÍ¨¹ýÓÐÃûº¯Êý±í´ïʽ´´½¨µÄÒ»¸öFunction¶ÔÏó¡£µ«ÊÇ´Ëʱwindow¶ÔÏóÖв¢²»´æÔÚfun2Õâ¸öÊôÐÔ£»
?
(6) Ö´ÐÐÍêµÚ19Ðкó£¬window.var6¸³ÖµÎª81£»
?
(7) Ö´ÐÐÍêµÚ20Ðкó£¬window.var6ÈÔÈ»ÊÇ81£¬ÒòΪÕâÖ»ÊÇÒ»¸ö±äÁ¿¶¨ÒåÓï¾ä£»
?
(8) Ö´ÐеÚ22ÐÐʱ³ö´í£¬ÒòΪÔÚwindowÖÐÕÒ²»µ½ÃûΪfun3µÄÊôÐÔ£¬¹Ê·µ»Ønull.fun3£¬ÊÔͼ¼ÆËãnull.fun3()ʱ±¨´í£»?
?
(9) ÔÚÒ»¸öÖ´Ðпé(script)Öгö´íºó£¬¸Ã¿éÖеĺóÐøJS½«²»ÔÙÖ´ÐУ¬¹Êvar4()²»»áÖ´ÐУ»µ«ÊǺóÃæscript±êÇ©Öп齫¼ÌÐøÖ´ÐÐ
?
(10) Ö´ÐеÚ26ÐÐ֮ǰ£¬´Ëʱ»áÔ¤´¦Àí¸Ãscript±êÇ©ÖеÄJSÔ´Â룬Á÷³ÌºÍ´¦ÀíµÚÒ»¸öscript±êÇ©ÏàËÆ¡£
?
(11) Ö´ÐеÚ27ÐÐʱ½«µ¯³öfun3¡£
?
?