官术网_书友最值得收藏!

Web performance - why are web pages slow?

Web development is difficult to get right. The web technology stack is complex, and there are many things between the web server and the user's device that can contribute to poor performance.

There are some things that you have no control over, such as the user's network quality or device grade. But there are plenty of things that affect performance that you do have control over. Some of the most significant of these factors are page size, resource loading, number of HTTP requests, and slow JavaScript execution:

  • Page size: In 2016, mobiForge (mobiforge.com) reported a sobering statistic: the average web page, at 2.3 MB, had grown as large as the original PC game, DOOM. Something is wrong when a web page needs to be the same size as a multi-level first-person shooter with an advanced 3D graphics engine.
    Many things can contribute to page size, including images, videos, ads, and third-party libraries (which themselves can include further third-party code).
  • Resource loading: The order in which a page's resources are loaded can significantly affect the performance of the page. A naive approach to resource loading would be to just queue up all resources and download them as the page loads. But then network bandwidth and CPU resources are wasted on downloading and rendering items that may never be seen by the user. A smarter approach is to only load items as they are needed.
  • Number of HTTP requests: Each external resource in a web page requires an HTTP request to fetch it. HTTP requests are slow, especially on mobile. HTTP requests can be reduced by inlining CSS and images where appropriate, and by including fewer external resources.
  • Slow JavaScript execution: Today, there are JavaScript libraries for just about any task you can think of. Including and using JavaScript libraries has never been easier. But this poses problems on mobile, where every library chews through precious CPU cycles, contributing to laggy and unresponsive pages.
主站蜘蛛池模板: 荣成市| 吉木萨尔县| 莎车县| 历史| 泰兴市| 大同县| 荥经县| 南京市| 上栗县| 黎平县| 当涂县| 白玉县| 襄汾县| 呼图壁县| 金川县| 阜新市| 巴塘县| 大姚县| 姜堰市| 苍山县| 广南县| 阿拉尔市| 罗甸县| 得荣县| 诸暨市| 济宁市| 高平市| 绵阳市| 巴东县| 湘潭市| 铜鼓县| 富顺县| 绿春县| 阳西县| 萨嘎县| 乃东县| 蒙山县| 哈尔滨市| 唐山市| 西平县| 浦城县|