React 出海应用 首屏加载时间从20S降到10S以下 血泪史

栏目: 服务器 · 发布时间: 5年前

内容简介:最近在做一个基于mobile app的漫画的项目,面向印尼市场。网址是http://id.mangaya.mobi上线后,基本测试没有问题,打开也挺顺畅。但是google analytics却反馈加载平均

最近在做一个基于mobile app的漫画的项目,面向印尼市场。

网址是http://id.mangaya.mobi

上线后,基本测试没有问题,打开也挺顺畅。但是google analytics却反馈加载平均 19s

React 出海应用 首屏加载时间从20S降到10S以下 血泪史

OMG~~于是开展了一系列的探索。。

首先说说技术栈,用的是create-react-app,redux,react-router,webpack4,babel7.

我们知道网页的加载流程大致如下:

React 出海应用 首屏加载时间从20S降到10S以下 血泪史

那么优化网页的加载速度,最本质的方式就是,1.减少请求数量 2.缩小请求体积大小。

减少请求数量

  1. 用base64减少不必要的网络请求,实际上create-react-app已经自动帮我们做了。
React 出海应用 首屏加载时间从20S降到10S以下 血泪史
  1. 引入文件使用React.Lazy
React 出海应用 首屏加载时间从20S降到10S以下 血泪史
  1. 图片延迟加载,使用react-lazyload,非常方便。
    React 出海应用 首屏加载时间从20S降到10S以下 血泪史
    React 出海应用 首屏加载时间从20S降到10S以下 血泪史

缩小请求体积大小

  1. 后台返回的图片使用webp格式,缩小体积。但是由于webp目前只被安卓支持,所以我们目前的方案是后端获取请求的user-agent信息,判断如果是ios的话,就返回jpg格式的图片,如果是安卓的话,就返回webp格式。这主要使用在banner图。

  2. webpack 处理

  • 2.1 build的时候去掉map文件,减少不必要的文件以及防止被查看源码

    React 出海应用 首屏加载时间从20S降到10S以下 血泪史
  • 2.2 压缩css和js,实际上create-react-app已经自动帮我们做了。uglifyjs-webpack-plugin使用的uglify-es已经不再被维护,取而代之的是一个名为terser的分支。

    React 出海应用 首屏加载时间从20S降到10S以下 血泪史
  • 2.3 默认splitChunk是 chunks: 'all' ,但是这样会导致生成一个很大的vendor文件,可以改一下,将node文件抽离出来。

splitChunks: {
        // chunks: 'all',
        chunks: "all",
        maxInitialRequests: Infinity,
        minSize: 0,
        cacheGroups: {
          vendor: {
            test: /[\\/]node_modules[\\/]/,
            name(module) {
              // get the name. E.g. node_modules/packageName/not/this/part.js
              // or node_modules/packageName
              const packageName = module.context.match(
                /[\\/]node_modules[\\/](.*?)([\\/]|$)/
              )[1];

              // npm package names are URL-safe, but some servers don't like @ symbols
              return `npm.${packageName.replace("@", "")}`;
            }
          }
        },
        name: false
      },
复制代码

这样虽然总的项目大小变大了,但是由于vendor文件被拆分成多个文件,根据http1.1或者http2的协议,浏览器资源获取是可以多个并行的,配合cdn,这样请求资源,反而更快。

  • 2.4 Babel polyfill的按需加载,直接在package.json配置就好了,由于需要支持的机子比较低端,所以设定为支持 >0.02% 的机型。可参考
"browserslist": [
    ">0.02%",
    "not dead",
    "not ie <= 11",
    "not op_mini all"
  ]
复制代码
  1. gzip压缩 如果浏览器支持gzip压缩,在发送请求的时候,请求头中会带有 Accept-Encoding:gzip 。然后服务器会将原始的response进行gzip压缩,并将gzip压缩后的response传输到浏览器,紧接着浏览器进行gzip解压缩,并最终反馈到网页上。
React 出海应用 首屏加载时间从20S降到10S以下 血泪史

资源cdn加速

将静态服务器改成印尼的服务器,明显dns以及静态资源的传输加快。最后就是cdn加速静态资源了,我把npm包的js都放到cdn上了,之后还可以配置多路cdn等策略。

同时我们还招募了志愿者帮我们测试嘻嘻嘻

当然这只是首次的加载的时间问题,后续还有观看漫画的优化工作,以及改成https协议加入pwa的service worker等等,敬请期待哈哈。


以上所述就是小编给大家介绍的《React 出海应用 首屏加载时间从20S降到10S以下 血泪史》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

解密搜索引擎技术实战

解密搜索引擎技术实战

罗刚 / 2011-6 / 69.80元

《解密搜索引擎技术实战-Lucene&Java精华版(附盘)》,本书主要包括总体介绍部分、爬虫部分、自然语言处理部分、全文检索部分以及相关案例分析。爬虫部分介绍了网页遍历方法和如何实现增量抓取,并介绍了从网页等各种格式的文档中提取主要内容的方法。自然语言处理部分从统计机器学习的原理出发,包括了中文分词与词性标注的理论与实现以及在搜索引擎中的实用等细节,同时对文档排重、文本分类、自动聚类、句法分析树......一起来看看 《解密搜索引擎技术实战》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具