[·Òë]High Performance JavaScript(032)
Fiddler
Fiddler is an HTTP debugging proxy that examines the assets coming over the wire and helps identify any loading bottlenecks. Created by Eric Lawrence, this is a general purpose network analysis tool for Windows that provides detailed reports on any browser or web request. Visit http://www.fiddler2.com/fiddler2/ for installation and other information.
FiddlerÊÇÒ»¸öHTTPµ÷ÊÔ´úÀí£¬¼ì²é×ÊÔ´ÔÚÏß´«ÊäÇé¿ö£¬ÒÔ¶¨Î»¼ÓÔØÆ¿¾±¡£ËüÓÉEric Lawrence´´½¨£¬ÊÇÒ»¸öWindowsÏÂͨÓõÄÍøÂç·ÖÎö¹¤¾ß£¬¿ÉΪÈκÎä¯ÀÀÆ÷»òÍøÒ³ÇëÇó¸ø³öÏêϸ±¨¸æ¡£Æä°²×°ºÍÆäËüÐÅÏ¢²Î¼ûhttp://www.fiddler2.com/fiddler2/¡£
During installation, Fiddler automatically integrates with IE and Firefox. A button is added to the IE toolbar, and an entry is added under Firefox's Tools menu. Fiddler can also be started manually. Any browser or application that makes web requests can be analyzed. While running, all WinINET traffic is routed through Fiddler, allowing it to monitor and analyze the performance of downloaded assets. Some browsers (e.g., Opera and Safari) do not use WinINET, but they will detect the Fiddler proxy automatically, provided that it is running prior to launching the browser. Any program that allows for proxy settings can be manually run through Fiddler by pointing it at the Fiddler proxy (127.0.0.1, port: 8888).
ÔÚ°²×°¹ý³ÌÖУ¬FiddlerÓëIEºÍFirefox×Ô¶¯¼¯³É¡£IE¹¤¾ßÀ¸ÉϽ«Ìí¼ÓÒ»¸ö°´Å¥£¬FirefoxµÄ¹¤¾ß²Ëµ¥Öн«Ôö¼ÓÒ»¸ö²Ëµ¥Ïî¡£Fiddler»¹¿ÉÒÔÊÖ¹¤Æô¶¯¡£ÈκÎä¯ÀÀÆ÷»òÓ¦ÓóÌÐò·¢ÆðµÄÍøÒ³ÇëÇó¶¼Äܹ»·ÖÎö¡£ËüÔËÐÐʱ£¬ËùÓÐWinINETͨÐŶ¼Í¨¹ýFiddler½øÐзÓÉ£¬ÔÊÐíËü¼àÊÓ²¢·ÖÎö×ÊÔ´ÏÂÔصÄÐÔÄÜ¡£Ä³Ð©ä¯ÀÀÆ÷£¨ÀýÈçOperaºÍSafari£©²»Ê¹ÓÃWinINET£¬µ«ËüÃÇ»á×Ô¶¯¼ì²âFiddler´úÀí£¬ÌÈÈôËüÔÚä¯ÀÀÆ÷Æô¶¯Ö®Ç°ÕýÔÚÔËÐеĻ°¡£ÈκÎÄܹ»ÉèÖôúÀíµÄ³ÌÐò¶¼¿ÉÒÔÊÖ¹¤ÉèÖÃÖ¸¶¨ËüʹÓÃFiddler´úÀí£¨127.0.0.1£¬¶Ë¿Ú£º8888£©¡£
Like Firebug, Web Inspector, and Page Speed, Fiddler provides a waterfall diagram that provides insights as to which assets are taking longer to load and
Ïà¹ØÎĵµ£º
±¾ÎÄÖ÷ÒªÊdzöÓÚÓÐÅóÓÑʹÓÃÎÒÔÀ´Ð´µÄautocompleteµÄJS¿Ø¼þ¡£µ±Êý¾ÝÁ¿´óµÄʱºò£¬»á³öÏÖЧÂʼ«ÆäÂýµÄÇé¿ö£¬ÎÒÔÚÕâ¶Îʱ¼ä×ö³öµÄһЩ²âÊÔÒ²¼°Ò»Ð©¾Ñ飬Óë´ó¼Ò·ÖÏí£¬Èç¹ûÓдíµÄµØ·½£¬»¹ÇëÖ¸³ö¡£
¾¹ý²âÊÔ£¬ÎÒÃǻᷢÏÖÈçϵÄÇé¿ö»òÕß˵µÄ½áÂÛ£¬Èç¹ûÄúµÄ²âÊÔ½á¹ûÓëÎҵIJ»·û£¬Çë˵Ã÷ÔÒò£¬ÒÔ±ãÏ໥ѧϰ¡£
1£©µ±Ò»¸ö½Ï´óµÄHTML×Ö· ......
Ò³ÃæÌá½»Êý¾ÝÒ»°ãÓÐÁ½ÖÖ·½·¨£ºget,post¡£post¾ÍÊÇËùνµÄformÌá½»£¬Ê¹ÓÃÊÓͼ£»getÊÇͨ¹ýurlÌá½»¡£
Get·½·¨Ò»°ãÓúǫ́´úÂ루Èçasp,asp.net£©»ñµÃ²ÎÊý£¬´úÂëºÜ¼òµ¥£ºRequest.QueryString["id"];¼´¿É»ñÈ¡¡£
ÓÐЩʱºòÐèÒªÖ±½ÓÔÚǰ̨»ñÈ¡url²ÎÊý£¬ÒªÓõ½javascript£¬jsûÓÐÖ±½Ó»ñÈ¡url²ÎÊýµÄ·½·¨£¬ÄÇô£¬ÎÒÃÇÈçºÎͨ¹ýjs ......
µÚÎåÕ Strings and Regular Expressions ×Ö·û´®ºÍÕýÔò±í´ïʽ
Practically all JavaScript programs are intimately tied to strings. For example, many applications use Ajax to fetch strings from a server, convert those strings into more easily usable JavaScript objects, and ......
Regular Expression Optimization ÕýÔò±í´ïʽÓÅ»¯
Incautiously crafted regexes can be a major performance bottleneck (the upcoming section, "Runaway Backtracking" on page 91, contains several examples showing how severe this can be), but there is a lot you can do to improve re ......
Splitting Up Tasks ·Ö½âÈÎÎñ
What we typically think of as one task can often be broken down into a series of subtasks. If a single function is taking too long to execute, check to see whether it can be broken down into a series of smaller functions that complete in smaller ......