½â¶ÁjavascriptµÄ¼ÆÊ±Æ÷
˵Ã÷£ºÕâÆªÎÄÕ½ÚÑ¡×ÔJohn Resig
µÄ¡¶Secrets of the JavaScript Ninja¡·Ò»Ê飬±¾ÈË·ÒëÖ»Êǹ©´ó¼Òѧϰ£¬·Òë²»×ãÖ®´¦£¬Ç븫Õý¡£
ÕâÆªÎÄÕÂÖ÷Òª´ÓÏÂÃæ¼¸¸ö·½Ãæ½â¶Á¼ÆÊ±Æ÷£º
¼ÆÊ±Æ÷¸ÅÊö£»
¼ÆÊ±Æ÷ËÙ¶ÈÉî¶È̽Îö£»
ÓüÆÊ±Æ÷´¦Àí´óÁ¿ÈÎÎñ£»
ÀûÓüÆÊ±Æ÷¹ÜÀí¶¯»£»
½ÏºÃµÄ¼ÆÊ±Æ÷²âÊÔ
¼ÆÊ±Æ÷ÊÇÒ»¸öÎÒÃÇÁ˽âºÜÉÙÇÒ¾³£±»ÀÄÓõĶ«Î÷£¬ËüÊÇjavascriptµÄÌØÉ«¡£Êµ¼ÊÉÏ£¬ÔÚ¸´ÔÓµÄÓ¦ÓóÌÐò¿ª·¢ÖУ¬ËüÄÜΪÎÒÃÇÌṩºÜ¶à°ïÖú¡£¼ÆÊ±Æ÷
ÌṩÁËÒ»¸ö¿ÉÒÔ½«´úÂëÆ¬¶ÎÒì²½ÑÓʱִÐеÄÄÜÁ¦£¬javascriptÉúÀ´Êǵ¥Ï̵߳ģ¨ÔÚÒ»¶¨Ê±¼ä·¶Î§ÄÚ½öÒ»²¿·Öjs´úÂëÄÜÔËÐУ©£¬¼ÆÊ±Æ÷ΪÎÒÃÇÌṩÁËÒ»ÖÖ
±Ü¿ªÕâÖÖÏÞÖÆµÄ·½·¨£¬´Ó¶ø¿ª±ÙÁËÁíÒ»ÌõÖ´ÐдúÂëµÄõè¾¶¡£
ÓÐȤµÄÊÇ£¬ÓëÎÒÃÇÆÕ±é½ÓÊܵĹ۵ãÏà·´£¬¼ÆÊ±Æ÷²¢²»ÊÇjavascriptÓïÑÔµÄÒ»²¿·Ö£¬¶øÊÇä¯ÀÀÆ÷ÒýÈëµÄ·½·¨ºÍ¶ÔÏóµÄÒ»²¿·Ö¡£ÕâÒâζ×ÅÈç¹ûÄãÑ¡ÔñÔÚÒ»¸ö·Çä¯ÀÀÆ÷µÄ»·¾³ÔËÐÐËü£¬ºÜÓпÉÄܼÆÊ±Æ÷²»´æÔÚ£¬Äã±ØÐëʹÓÃÌØ¶¨¹¦ÄÜÍÆÐÐÄã×Ô¼ºµÄ°æ±¾£¨ÈçRhinoỊ̈߳©¡£
1¡¢¼ÆÊ±Æ÷ÊÇÈçºÎ¹¤×÷µÄ
´Ó¸ù±¾ÉÏÀ´Ëµ£¬Àí½â¼ÆÊ±Æ÷ÈçºÎ¹¤×÷ºÜÖØÒª¡£Í¨³£Çé¿öÏ£¬¼ÆÊ±Æ÷µÄÐÐΪ²¢²»Ö±¹Û£¬ÒòΪËüÔÚÒ»¸öµ¥¶ÀµÄÏß³ÌÖУ¬ÈÃÎÒÃÇ´ÓÈý¸öº¯ÊýµÄ²âÊÔ¿ªÊ¼£¬¶ÔÓÚÿһ¸öº¯ÊýÎÒÃǶ¼Óлú»á¹¹½¨ºÍ¿ØÖƼÆÊ±Æ÷¡£
var id = setTimeout(fn,delay)£»Æô¶¯Ò»¸ö¼ÆÊ±Æ÷£¬Ëü½«ÔÚÑÓ³Ùʱ¼äÖ®ºóµ÷ÓÃÌØ¶¨µÄº¯Êý£¬¸Ãº¯Êý·µ»ØÒ»¸öΨһµÄID£¬ÀûÓÃÕâ¸öID¼ÆÊ±Æ÷ÔÚÉÔºóµÄʱ¼äÀﱻȡÏû£»
var id = setInterval(fn,delay)£»ÓësetTimeoutÏàËÆ£¬µ«Ëü²»¶ÏµÄµ÷Óú¯Êý£¨Ã¿¸ôÒ»¶¨ÑÓ³Ùʱ¼ä£©Ö±µ½Ëü±»È¡Ïû£»
clearInterval(id)£¬clearTimeout(id)£»½ÓÊܼÆÊ±Æ÷µÄ ID£¨ÓÉÉÏÊöÈÎÒâÒ»¸öº¯Êý·µ»Ø£©²¢Í£Ö¹µ÷ÓüÆÊ±Æ÷¡£
ΪÁËÀí½â¼ÆÊ±Æ÷ÄÚ²¿ÊÇÈçºÎ¹¤×÷µÄ£¬ÓÐÒ»¸öºÜÖØÒªµÄ¸ÅÄîÐèÒª¼ÓÒÔ̽ÌÖ£ºÑÓ³ÙÊÇÎÞ·¨±£Ö¤µÄ¡£¼ÈÈ»ä¯ÀÀÆ÷ÖÐËùÓÐjavascript ÊÇÔÚÒ»¸öµ¥Ïß³ÌÖÐÔËÐеģ¬ÄÇôÒ첽ʼþ£¨ÈçÊó±êµã»÷¡¢¼ÆÊ±Æ÷£©ÔÚÖ´ÐÐÖÐÒ²Ö»ÓдæÔÚ¿ª·Å״̬ʱ²ÅÔËÐУ¬ÏÂÃæÕâÕÅͼºÜºÃµÄ˵Ã÷ÁËÕâ¸öÎÊÌ⣺
ÕâÕÅͼÓкܶàÐÅÏ¢ÐèÒªÏû»¯£¬³ä·ÖÀí½âËü½«Ê¹Äã¶ÔÒì²½jsÖ´ÐÐÓÐÒ»¸ö¸üºÃµÄÈÏʶ£¬Í¼±íÊÇһάµÄ£¬ÔÚ´¹Ö±·½ÏòÉÏÊÇʱ¼ä£¨¹ÒÖÓ£©£¬ÒÔºÁÃëΪµ¥Î»¡£À¶É«ºÐ×Ó´ú±íjsÖ´ÐеıÈÀý¡£ÀýÈ磬µÚÒ»¸öjavascript¿éÔËÐÐʱ¼ä´óԼΪ18Ã룬Êó±êµã»÷´óԼΪ11ÃëµÈµÈ¡£
¼ÈÈ»javascriptÔÚÒ»¶¨Ê±¼äÄÚÖ®Ö´ÐÐÒ»²¿·Ö´úÂ루ԴÓÚµ¥Ï̵߳ÄÌØÐÔ£©£¬ÄÇôÕâЩ´úÂë¿éµÄÿһ¸ö¾Í±»·âËøÔÚÆäËüÒ첽ʼþÖ´ÐеĽø³ÌÖС£Õâ±íÃ÷
µ±Ò»¸öÒ첽ʼþ·¢Éúʱ£¨ÈçÊó±êµã»÷¡¢¼ÆÊ±Æ÷ÊÍ·Å¡¢XM
Ïà¹ØÎĵµ£º
scrollHeight: »ñÈ¡¶ÔÏóµÄ¹ö¶¯¸ß¶È¡£
scrollLeft:ÉèÖûò»ñȡλÓÚ¶ÔÏó×ó±ß½çºÍ´°¿ÚÖÐĿǰ¿É¼ûÄÚÈݵÄ×î×ó¶ËÖ®¼äµÄ¾àÀë
scrollTop:ÉèÖûò»ñȡλÓÚ¶ÔÏó×î¶¥¶ËºÍ´°¿ÚÖпɼûÄÚÈݵÄ×î¶¥¶ËÖ®¼äµÄ¾àÀë
scrollWidth:»ñÈ¡¶ÔÏóµÄ¹ö¶¯¿í¶È
offsetHeight:»ñÈ¡¶ÔÏóÏà¶ÔÓÚ°æÃæ»òÓɸ¸×ø±ê offsetParent ÊôÐÔÖ¸¶¨µÄ¸¸×ø±êµÄ¸ß¶È
offsetL ......
ÀûÓÃJavascript´´½¨µ¯³öʽ´°¿ÚµÄÄ¿µÄʵ¼ÊÉÏÊÇ´ò¿ªÁíÍâµÄä¯ÀÀÆ÷´°¿Ú¡£Äã¿ÉÒÔÉèÖÃÕâ¸öä¯ÀÀÆ÷´°¿ÚµÄһЩÊôÐÔ£¬Èç¸ß¶È¡¢¿í¶ÈÒÔ¼°ÊÇ·ñÈøô°¿ÚÓÐÒ»¸ö״̬Ìõ»òÕß¹¤¾ßÌõ¡£ÔÚÏÂÃæµÄÀý×ÓÖУ¬ÎÒ½«´°¿ÚÉèÖÃΪ£º350
x 400£¬¼´¸ß¶ÈΪ350ÏñËØ£¬¿í¶ÈΪ400ÏñËØ£»ÆäÖÐÒ²°üÀ¨ÁËÁíÍâµÄһЩÉèÖã¬Èç¹ö¶¯Ìõ£»¶ø½«ÆäËüµÄÉèÖã¨Èç״̬Ìõ¡¢²Ëµ¥Ìõ£© ......
Ëæ×Å»¥ÁªÍøµÄ·ÉËÙ·¢Õ¹£¬µØÇò±äµÃÔ½À´Ô½Ð¡£¬ÈËÃÇ¿ÉÒÔ¿çԽʱ¼äºÍ¿Õ¼äµÃ½çÏÞ½øÐн»Á÷ÓÚºÏ×÷¡£µ«ÊÇËæÖ®Ò²²úÉúÁËһЩËÁÒâ¸ãÆÆ»µµÄºÚ¿Í£¬Õâ¾ÍʹµÃ³ÌÐòÉè¼ÆÈËÔ±ÔÚ±àÖÆÓ¦ÓóÌÐòÖÐÒª¿¼Âǵ½ºÚ¿ÍÏ®»÷Õâ¸öÎÊÌ⣬ËùÒÔ×ÔÈ»¶øÈ»µØ¾Í»áÏëµ½±£»¤¡£±¾½Ú½Ì³Ì½«½ÌÄãÔõÑùÀûÓÃjavascript½øÐÐÃÜÂë±£»¤¡£ÀûÓà JavaScriptÀ´¶ÔÍøÒ³½øÐÐÃÜÂë±£»¤Óм¸ÖÖ· ......
1£¬ jsÖеÄÀàÊý×é¶ÔÏó
(1) arguments¶ÔÏó:
function(){
//arguments¶ÔÏóÊÇArguments¶ÔÏóʵÀý£¬ÊÇÒ»¸öÀàÊý×é¶ÔÏ󣬲¢ÓµÓÐÏÂÁз½·¨
alert(arguments instanceof Array);//false
arguments.callee(); //¶Ô×ÔÉíµÄµ÷Ó㬠ÓÃÓڵݹé
var c = arguments.caller; //¶Ôµ÷ÓÃ×ÔÉíº¯ÊýµÄ¸¸º¯Êý, Èç¹û ......
javascriptʼþÁбí½â˵
ʼþ
ä¯ÀÀÆ÷Ö§³Ö
½â˵
Ò»°ãʼþ
onclick
IE3¡¢N2
Êó±êµã»÷ʱ´¥·¢´Ëʼþ
ondblclick
IE4¡¢N4
Êó±êË«»÷ʱ´¥·¢´Ëʼþ
onmousedown
IE4¡¢N4
°´ÏÂÊó±êʱ´¥·¢´Ëʼþ
onmouseup
IE4¡¢N4
Êó±ê°´ÏºóËÉ¿ªÊó±êʱ´¥·¢´Ëʼþ
onmouseover
IE3¡¢N2
µ±Êó±êÒÆ¶¯µ½Ä³¶ÔÏó·¶Î§µÄÉÏ·½Ê±´¥·¢´Ëʼ ......