VUE單頁應用首屏加載速度優化方案

單頁應用會隨着項目越大,致使首屏加載速度很慢!!!如下給出在下知道的幾種優化方案css

  1. 使用CDN資源,減少服務器帶寬壓力
  2. 路由懶加載
  3. 將一些靜態js css放到其餘地方(如OSS),減少服務器壓力
  4. 按需加載三方資源,如iview,建議按需引入iview中的組件
  5. 使用nginx開啓gzip減少網絡傳輸的流量大小
  6. 若首屏爲登陸頁,能夠作成多入口,登陸頁單獨分離爲一個入口
  7. 使用uglifyjs-webpack-plugin插件代替webpack自帶UglifyJsPlugin插件

使用CDN資源,減少服務器帶寬壓力

  • 在index.html中引入cdn資源
...
  <body>
    <div id="app">
    </div>
    <!-- built files will be auto injected -->
    <script src="https://cdn.bootcss.com/vue/2.5.2/vue.min.js"></script>
    <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>
    <script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script>
    <script src="https://cdn.bootcss.com/vue-resource/1.5.1/vue-resource.min.js"></script>
  </body>
  ...
  • 修改 build/webpack.base.conf.js
module.exports = {
  context: path.resolve(__dirname, '../'),
  entry: {
    app: './src/main.js'
  },
  externals:{
    'vue': 'Vue',
    'vue-router': 'VueRouter',
    'vuex':'Vuex',
    'vue-resource': 'VueResource'
  },
  ...
}
  • 修改src/main.js src/router/index.js 註釋掉import引入的vue,vue-resource
// import Vue from 'vue'
// import VueResource from 'vue-resource'
// Vue.use(VueResource)

路由懶加載

require.ensure方式html

const workCircle = r => require.ensure([], () => r(require('@/module/work-circle/Index')), 'workCircle')
const workCircleList = r => require.ensure([], () => r(require('@/module/work-circle/page/List')), 'workCircleList')

import方式前端

const workCircle = () => import('@/module/work-circle/Index')

將一些靜態js css放到其餘地方(如OSS),減少服務器壓力

注意這裏的js文件,須要將結果拋出,而後在須要用到該js的組件中import引入vue

按需加載三方資源,如iview,建議按需引入iview中的組件

按需引用請查看iview官方文檔iviewnode

使用nginx開啓gzip減少網絡傳輸的流量大小

clipboard.png

配置nginx,能夠參考Nginx開啓Gzip壓縮大幅提升頁面加載速度webpack

webpack開啓gzip壓縮。 只須要服務器開啓gzip壓縮,服務器開啓gzip壓縮後,服務器拿到咱們部署上去的文件,會壓縮文件而後返回給瀏覽器。因此前端使用gzip壓縮是沒有起做用的。因此compression-webpack-plugin插件有什麼用,各位探討下QAQ

這裏須要配合Nginx服務器,Nginx開啓gzipnginx

clipboard.png

webpack4.x如下使用compression-webpack-plugin插件,插件版本應使用1.x
webpack4.x版本以上可使用compression-webpack-plugin 2.x
  • config/index.js中
module.exports = {
  build: {
    ...
    // Gzip off by default as many popular static hosts such as
    // Surge or Netlify already gzip all static assets for you.
    // Before setting to `true`, make sure to:
    // npm install --save-dev compression-webpack-plugin
    productionGzip: true, // 就是這裏開啓gzip,vue-cli搭建項目,這裏默認爲false
    productionGzipExtensions: ['js', 'css'],

    // Run the build command with an extra argument to
    // View the bundle analyzer report after build finishes:
    // `npm run build --report`
    // Set to `true` or `false` to always turn it on or off
    bundleAnalyzerReport: process.env.npm_config_report
  }
}
  • build/webpack.prod.conf.js中

使用vue-cli構建項目時,默認會有這段代碼es6

if (config.build.productionGzip) {
  const CompressionWebpackPlugin = require('compression-webpack-plugin')
  webpackConfig.plugins.push(
    new CompressionWebpackPlugin({
      asset: '[path].gz[query]',
      algorithm: 'gzip',
      test: new RegExp(
        '\\.(' +
        config.build.productionGzipExtensions.join('|') +
        ')$'
      ),
      threshold: 10240,
      minRatio: 0.8
    })
  )
}

若首屏爲登陸頁,能夠作成多入口,登陸頁單獨分離爲一個入口

使用uglifyjs-webpack-plugin插件代替webpack自帶UglifyJsPlugin插件

兩個插件都不支持es6壓縮,因此使用此插件前須要用工具(如babel-loader)轉換es6代碼web

問題描述:項目中使用iview時,致使使用UglifyJsPlugin壓縮報錯
由於iview某插件中包含es6語法。然而兩個插件都不支持es6壓縮

解決方法以下:vue-router

  • 修改webpack配置文件,使用babel-loader轉換一下iview插件中的es6語法
module.exports = {
  entry: {
    app: './src/main.js'
  },
  output: {
    path: config.build.assetsRoot,
    filename: '[name].js',
    publicPath: process.env.NODE_ENV === 'production'
      ? config.build.assetsPublicPath
      : config.dev.assetsPublicPath
  },
...
  module: {
    loaders: [
      { test: /iview.src.*?js$/, loader: 'babel' },
      { test: /\.js$/, loader: 'babel', exclude: /node_modules/ }
    ],
    rules: [
    ...
      {
        test: /\.js$/,
        loader: 'babel-loader',
         // resolve('/node_modules/iview/src'),resolve('/node_modules/iview/packages')解決iview打包時UglifyJs報錯
        include: [resolve('src'), resolve('test'), resolve('/node_modules/iview/src'),resolve('/node_modules/iview/packages')]
      }
      ...
    ]
  }
}
  • webpack生產環境中
...
const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
...
    new UglifyJsPlugin({
      // 使用外部引入的新版本的js壓縮工具
      parallel: true,
      uglifyOptions: {
        ie8: false, // 啓用IE8支持
        ecma: 6, // 支持的ECMAScript的版本(5,6,7或8)。影響parse,compress&& output選項
        warnings: false, // 顯示警告
        mangle: true, // debug false
        output: {
          comments: false,
          beautify: false, // debug true
        },
        compress: {
          // 在UglifyJs刪除沒有用到的代碼時不輸出警告
          warnings: false,
          // 刪除全部的 `console` 語句
          // 還能夠兼容ie瀏覽器
          drop_console: true,
          // 內嵌定義了可是隻用到一次的變量
          collapse_vars: true,
          // 提取出出現屢次可是沒有定義成變量去引用的靜態值
          reduce_vars: true,
        }
      }
    }),
    // new webpack.optimize.UglifyJsPlugin({
    //   compress: {
    //     warnings: false
    //   },
    //   sourceMap: true
    // }),

此方法有待實踐,留待下次分享 ==

相關文章
相關標籤/搜索