```javascript//sw.jsÎļþÄÚÈÝself.addEventListener('install',event=>{event.waitUntil(caches.open('v1').then(cache=>{returncache.addAll('/','/index.html','/styles.css','/script.js','/image.png');}));});
ʾÀý´úÂ룺
//×¢²á?ЧÀÍÊÂÇéÆ÷if('serviceWorker'innavigator){navigator.serviceWorker.register('/sw.js').then(registration=>{console.log('ServiceWorkerregisteredwithscope:',registration.scope);}).catch(error=>{console.error('ServiceWorkerregistrationfailed:',error);});}
TTP/2ÐÒ飺
HTTP/2ÊÇÒ»ÖÖеÄWeb´«ÊäÐÒ飬Ïà±ÈÓڹŰåµÄHTTP/1.1£¬ËüÌṩÁ˶à¸öÏÔÖøµÄ¸ïУ¬°üÀ¨¶à·¾¶¡¢Í·²¿Ñ¹Ëõ¡¢¸ü¸ßµÄ²¢·¢ÐÔµÈ?¡£ÕâÐ©ÌØÐÔ¿ÉÒÔ´ó?´óÌáÉýÍøÒ³µÄ¼ÓÔØËÙ¶È¡£
¶à·¾¶£ºÔڹŰåµÄHTTP/1.1ÖУ¬Ã¿´ÎÇëÇó¶¼ÐèÒª½¨Á¢Ò»¸öеÄ?Á¬½Ó£¬¶øHTTP/2ÔÊÐíÔÚµ¥¸öTCPÁ¬½ÓÉÏ´«Êä¶à¸öÇëÇ󣬼õÉÙÁËÁ¬½Ó½¨Á¢µÄʱ¼ä¡£Í·²¿Ñ¹Ëõ£ºHTTP/2ͨ¹ý¶ÔÇëÇóÍ·²¿½øÐÐѹËõ£¬¼õÉÙÁËÊý¾Ý´«ÊäµÄ¾Þϸ£¬´Ó¶øÌá¸ßÁË´«ÊäËÙ¶È¡£¸ü¸ßµÄ?²¢·¢ÐÔ£ºHTTP/2ÔÊÐí¶à¸öÇëÇóÔÚͬһÁ¬½ÓÉϲ¢Ðд«Ê䣬¶ø²»ÊǹŰåµÄÒ»¸öÇëÇóÒ»¸öÁ¬½ÓµÄ·½·¨¡£
ΪÁËÆôÓÃHTTP/2£¬ÄúÐèÒªÔÚЧÀÍÆ÷¶Ë½øÐÐÅäÖá£ÀýÈ磬ÔÚApacheЧÀÍÆ÷ÖУ¬¿ÉÒÔͨ¹ýÌí¼ÓÒÔÏÂÅäÖÃÀ´ÆôÓÃHTTP/2£º
Listen443http2
ºÏÀí¼Æ»®Ìø×ª´°¿ÚÄÚÈÝ
ÔÚÉèÖÃÌø×ª´°¿Úʱ£¬Ó¦Æ¾¾Ýʵ¼ÊÐèÇóºÏÀí¼Æ»®ÄÚÈÝ¡£½«×î³£ÓúÍ×îÖØÒªµÄÐÅÏ¢»òЧÀÍ·ÅÔÚÏÔÑÛµÄλÖ㬱ãÓÚ¿ìËÙ»á¼û¡£¿ÉÒÔÆ¾¾Ý²»?ͬµÄ¸ÚλºÍÐèÇó£¬ÉèÖòî±ðµÄÌø×ª´°¿Ú£¬È·±£Ã¿¸öÓû§¶¼ÄÜ»ñµÃ×îÊʺÏËûÃǵÄÐÅÏ¢¡£
½¨Ò飺°´ÆÚÉóºËºÍ¸üÐÂÌø×ª´°¿ÚÄÚÈÝ£¬È·±£ÐÅÏ¢µÄʵʱÐÔºÍ׼ȷÐÔ¡£¿ÉÒÔͨ¹ýÓû§·´ÏìºÍÊý¾ÝÆÊÎö£¬ÓÅ»¯Ìø×ª´°¿ÚµÄ½á¹¹ºÍÄÚÈÝ¡£
Êý¾ÝÄþ¾²ºÍÒþ˽±£»¤
ÔÚʹÓÃ17CÖ±½ÓÌø×ª´°¿Úʱ£¬ÐèÒªÌØ±ð×¢ÒâÊý¾ÝÄþ¾²ºÍÒþ˽±£»¤¡£È·±£Ìø×ª´°¿ÚÖеÄÐÅÏ¢ºÍÊý¾Ý´«ÊäʹÓÃÁ˼ÓÃܼ¼Êõ£¬±ÜÃâÐÅϢй¶¡£ÉèÖòî±ðÓû§µÄ»á¼ûȨÏÞ£¬È·±£Ãô¸ÐÐÅÏ¢Ö»ÓÐÊÚȨÈËÔ±²Å»ª»á¼û¡£
½¨Ò飺°´ÆÚ½øÐÐÄþ¾²É󼯣¬¼ì²éϵͳµÄ°²?È«ÉèÖúÍÅäÖã¬ÊµÊ±·¢Ã÷Ï¢Õù¾öÄþ¾²Òþ»¼¡£Ìá¸ßÔ±¹¤µÄÄþ¾²Òâʶ£¬ÅàÑøÁ¼ºÃµÄÄþ¾²Ê¹ÓÃϰ¹ß¡£
ǰ¶ËÓÅ»¯£º
¼õÉÙHTTPÇëÇó£ºÍ¨¹ý¼õÉÙÍøÒ³ÖеÄͼƬ¡¢Ñùʽ±íºÍJavaScriptÎļþÊýÁ¿£¬¿ÉÒÔ¼õÉÙHTTPÇëÇó£¬ÌáÉý¼ÓÔØËÙ¶È¡£ºÏ²¢ºÍѹËõÎļþ£º½«¶à¸öCSSºÍJavaScriptÎļþºÏ²¢ÎªÒ»¸öÎļþ£¬²¢½øÐÐѹËõ£¬ÒÔ¼õÉÙÎļþ¾ÞϸºÍ¼ÓÔØÊ±¼ä¡£Òì²½¼ÓÔØ£ºÊ¹ÓÃasync»òdeferÊôÐÔÀ´Òì²½¼ÓÔØJavaScriptÎļþ£¬´Ó¶ø²»?×èÈûÒ³ÃæµÄÆäËû²¿·Ö¡£
У¶Ô£º½»ÝÒÇ(1C0m4pJyqZtPma0S7t9ZFfz4hTykKag)


