国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

VUE單頁應(yīng)用首屏加載速度優(yōu)化方案

jubincn / 1476人閱讀

摘要:所以前端使用壓縮是沒有起作用的。影響,選項(xiàng)顯示警告在刪除沒有用到的代碼時(shí)不輸出警告刪除所有的語句還可以兼容瀏覽器內(nèi)嵌定義了但是只用到一次的變量提取出出現(xiàn)多次但是沒有定義成變量去引用的靜態(tài)值此方法有待實(shí)踐,留待下次分享

單頁應(yīng)用會(huì)隨著項(xiàng)目越大,導(dǎo)致首屏加載速度很慢!!!以下給出在下知道的幾種優(yōu)化方案

使用CDN資源,減小服務(wù)器帶寬壓力

路由懶加載

將一些靜態(tài)js css放到其他地方(如OSS),減小服務(wù)器壓力

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

使用nginx開啟gzip減小網(wǎng)絡(luò)傳輸?shù)牧髁看笮?/p>

若首屏為登錄頁,可以做成多入口,登錄頁多帶帶分離為一個(gè)入口

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

使用CDN資源,減小服務(wù)器帶寬壓力

在index.html中引入cdn資源

...
  
    
...

修改 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方式

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")
將一些靜態(tài)js css放到其他地方(如OSS),減小服務(wù)器壓力

注意這里的js文件,需要將結(jié)果拋出,然后在需要用到該js的組件中import引入

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

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

使用nginx開啟gzip減小網(wǎng)絡(luò)傳輸?shù)牧髁看笮?/b>

配置nginx,可以參考Nginx開啟Gzip壓縮大幅提高頁面加載速度

webpack開啟gzip壓縮。 只需要服務(wù)器開啟gzip壓縮,服務(wù)器開啟gzip壓縮后,服務(wù)器拿到我們部署上去的文件,會(huì)壓縮文件然后返回給瀏覽器。所以前端使用gzip壓縮是沒有起作用的。所以compression-webpack-plugin插件有什么用,各位探討下QAQ

這里需要配合Nginx服務(wù)器,Nginx開啟gzip

clipboard.png

webpack4.x以下使用compression-webpack-plugin插件,插件版本應(yīng)使用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搭建項(xiàng)目,這里默認(rèn)為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構(gòu)建項(xiàng)目時(shí),默認(rèn)會(huì)有這段代碼

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
    })
  )
}
若首屏為登錄頁,可以做成多入口,登錄頁多帶帶分離為一個(gè)入口 使用uglifyjs-webpack-plugin插件代替webpack自帶UglifyJsPlugin插件

兩個(gè)插件都不支持es6壓縮,所以使用此插件前需要用工具(如babel-loader)轉(zhuǎn)換es6代碼

問題描述:項(xiàng)目中使用iview時(shí),導(dǎo)致使用UglifyJsPlugin壓縮報(bào)錯(cuò)
因?yàn)閕view某插件中包含es6語法。然而兩個(gè)插件都不支持es6壓縮

解決方法如下:

修改webpack配置文件,使用babel-loader轉(zhuǎn)換一下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打包時(shí)UglifyJs報(bào)錯(cuò)
        include: [resolve("src"), resolve("test"), resolve("/node_modules/iview/src"),resolve("/node_modules/iview/packages")]
      }
      ...
    ]
  }
}

webpack生產(chǎn)環(huán)境中

...
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選項(xiàng)
        warnings: false, // 顯示警告
        mangle: true, // debug false
        output: {
          comments: false,
          beautify: false, // debug true
        },
        compress: {
          // 在UglifyJs刪除沒有用到的代碼時(shí)不輸出警告
          warnings: false,
          // 刪除所有的 `console` 語句
          // 還可以兼容ie瀏覽器
          drop_console: true,
          // 內(nèi)嵌定義了但是只用到一次的變量
          collapse_vars: true,
          // 提取出出現(xiàn)多次但是沒有定義成變量去引用的靜態(tài)值
          reduce_vars: true,
        }
      }
    }),
    // new webpack.optimize.UglifyJsPlugin({
    //   compress: {
    //     warnings: false
    //   },
    //   sourceMap: true
    // }),

此方法有待實(shí)踐,留待下次分享 ==

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/40082.html

相關(guān)文章

  • VUE單頁應(yīng)用首屏加載速度優(yōu)化方案

    摘要:所以前端使用壓縮是沒有起作用的。影響,選項(xiàng)顯示警告在刪除沒有用到的代碼時(shí)不輸出警告刪除所有的語句還可以兼容瀏覽器內(nèi)嵌定義了但是只用到一次的變量提取出出現(xiàn)多次但是沒有定義成變量去引用的靜態(tài)值此方法有待實(shí)踐,留待下次分享 單頁應(yīng)用會(huì)隨著項(xiàng)目越大,導(dǎo)致首屏加載速度很慢!!!以下給出在下知道的幾種優(yōu)化方案 使用CDN資源,減小服務(wù)器帶寬壓力 路由懶加載 將一些靜態(tài)js css放到其他地方(如...

    lewif 評論0 收藏0
  • vue從零開發(fā)和部署一款移動(dòng)端pwa單頁應(yīng)用

    摘要:另外,單頁應(yīng)用因?yàn)閿?shù)據(jù)前置到了前端,不利于搜索引擎的抓取。所以我們需要對自己的單頁應(yīng)用進(jìn)行一些優(yōu)化。 前言 最近秋招之余空出時(shí)間來按自己的興趣動(dòng)手做了一個(gè)項(xiàng)目,一個(gè)基于vue-cli3.0, vue,typescript的移動(dòng)端pwa,現(xiàn)在趁熱打鐵,將這個(gè)項(xiàng)目從開發(fā)到部署整個(gè)過程記錄下來,并將從這個(gè)項(xiàng)目中學(xué)習(xí)到的東西分享出來,如果大家有什么意見或補(bǔ)充也可以在評論區(qū)提出。先介紹一下這個(gè)項(xiàng)...

    Channe 評論0 收藏0
  • Vue SPA(單頁應(yīng)用)首屏優(yōu)化實(shí)踐

    摘要:原文首發(fā)代碼壓縮如果你用的是服務(wù)器,請修改配置文件其他類似在里加入開啟或者關(guān)閉模塊,這里使用表示啟動(dòng)設(shè)置允許壓縮的頁面最小字節(jié)數(shù)默認(rèn)值是,不管頁面多大都?jí)嚎s設(shè)置系統(tǒng)獲取幾個(gè)單位的緩存用于存儲(chǔ)的壓縮結(jié)果數(shù)據(jù)流代表以為單位,按照原始數(shù)據(jù)大 原文首發(fā): https://shuirong.github.io/ 1.代碼壓縮(gzip) 如果你用的是nginx服務(wù)器,請修改配置文件(其他web ...

    wall2flower 評論0 收藏0
  • 前端經(jīng)驗(yàn) - 收藏集 - 掘金

    摘要:我拖拖拖拖放基礎(chǔ)篇前端掘金不要搞錯(cuò),本文不是講如何拖地的。結(jié)構(gòu)說明前端應(yīng)該從哪些方面來優(yōu)化網(wǎng)站前端掘金不知道是哪位大牛的文章,轉(zhuǎn)過來回答。 我拖拖拖 --H5 拖放 API 基礎(chǔ)篇 - 前端 - 掘金不要搞錯(cuò),本文不是講如何拖地的。看過《javascript精粹》朋友應(yīng)該知道,他實(shí)現(xiàn)拖放的過程比較復(fù)雜,現(xiàn)在時(shí)代不同了,我們用H5的新的拖放API就能非常方便的實(shí)現(xiàn)拖放效果了。最近在園子見...

    MudOnTire 評論0 收藏0
  • vue首屏加載優(yōu)化

    摘要:為了讓事情更簡單,允許將組件定義為一個(gè)工廠函數(shù),動(dòng)態(tài)地解析組件的定義。只在組件需要渲染時(shí)觸發(fā)工廠函數(shù),并且把結(jié)果緩存起來,用于后面的再次渲染。 庫使用情況 vue vue-router axios muse-ui material-icons vue-baidu-map 未優(yōu)化前 首先我們在正常情況下buildshowImg(https://segmentfault.com/img...

    Kaede 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<