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

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.
主站蜘蛛池模板: 呼图壁县| 凤凰县| 芜湖市| 上饶县| 松潘县| 宜城市| 宣城市| 陈巴尔虎旗| 南召县| 巴林左旗| 阳春市| 甘南县| 古蔺县| 肇东市| 百色市| 德州市| 新绛县| 东至县| 淮滨县| 南澳县| 晴隆县| 文山县| 灵璧县| 新丰县| 钦州市| 孝感市| 阳春市| 习水县| 雷山县| 囊谦县| 松桃| 怀柔区| 土默特右旗| 昌乐县| 铁岭市| 吐鲁番市| 且末县| 茂名市| 怀化市| 阳江市| 苏尼特右旗|