摘要:所以前端使用壓縮是沒有起作用的。影響,選項顯示警告在刪除沒有用到的代碼時不輸出警告刪除所有的語句還可以兼容瀏覽器內嵌定義了但是只用到一次的變量提取出出現多次但是沒有定義成變量去引用的靜態值此方法有待實踐,留待下次分享
單頁應用會隨著項目越大,導致首屏加載速度很慢!!!以下給出在下知道的幾種優化方案
使用CDN資源,減小服務器帶寬壓力
路由懶加載
將一些靜態js css放到其他地方(如OSS),減小服務器壓力
按需加載三方資源,如iview,建議按需引入iview中的組件
使用nginx開啟gzip減小網絡傳輸的流量大小
若首屏為登錄頁,可以做成多入口,登錄頁多帶帶分離為一個入口
使用uglifyjs-webpack-plugin插件代替webpack自帶UglifyJsPlugin插件
使用CDN資源,減小服務器帶寬壓力在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")將一些靜態js css放到其他地方(如OSS),減小服務器壓力
注意這里的js文件,需要將結果拋出,然后在需要用到該js的組件中import引入
按需加載三方資源,如iview,建議按需引入iview中的組件按需引用請查看iview官方文檔iview
使用nginx開啟gzip減小網絡傳輸的流量大小配置nginx,可以參考Nginx開啟Gzip壓縮大幅提高頁面加載速度
webpack開啟gzip壓縮。 只需要服務器開啟gzip壓縮,服務器開啟gzip壓縮后,服務器拿到我們部署上去的文件,會壓縮文件然后返回給瀏覽器。所以前端使用gzip壓縮是沒有起作用的。所以compression-webpack-plugin插件有什么用,各位探討下QAQ這里需要配合Nginx服務器,Nginx開啟gzip
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構建項目時,默認會有這段代碼
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代碼
問題描述:項目中使用iview時,導致使用UglifyJsPlugin壓縮報錯
因為iview某插件中包含es6語法。然而兩個插件都不支持es6壓縮
解決方法如下:
修改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 // }),
此方法有待實踐,留待下次分享 ==
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/97054.html
摘要:所以前端使用壓縮是沒有起作用的。影響,選項顯示警告在刪除沒有用到的代碼時不輸出警告刪除所有的語句還可以兼容瀏覽器內嵌定義了但是只用到一次的變量提取出出現多次但是沒有定義成變量去引用的靜態值此方法有待實踐,留待下次分享 單頁應用會隨著項目越大,導致首屏加載速度很慢!!!以下給出在下知道的幾種優化方案 使用CDN資源,減小服務器帶寬壓力 路由懶加載 將一些靜態js css放到其他地方(如...
摘要:另外,單頁應用因為數據前置到了前端,不利于搜索引擎的抓取。所以我們需要對自己的單頁應用進行一些優化。 前言 最近秋招之余空出時間來按自己的興趣動手做了一個項目,一個基于vue-cli3.0, vue,typescript的移動端pwa,現在趁熱打鐵,將這個項目從開發到部署整個過程記錄下來,并將從這個項目中學習到的東西分享出來,如果大家有什么意見或補充也可以在評論區提出。先介紹一下這個項...
摘要:原文首發代碼壓縮如果你用的是服務器,請修改配置文件其他類似在里加入開啟或者關閉模塊,這里使用表示啟動設置允許壓縮的頁面最小字節數默認值是,不管頁面多大都壓縮設置系統獲取幾個單位的緩存用于存儲的壓縮結果數據流代表以為單位,按照原始數據大 原文首發: https://shuirong.github.io/ 1.代碼壓縮(gzip) 如果你用的是nginx服務器,請修改配置文件(其他web ...
摘要:我拖拖拖拖放基礎篇前端掘金不要搞錯,本文不是講如何拖地的。結構說明前端應該從哪些方面來優化網站前端掘金不知道是哪位大牛的文章,轉過來回答。 我拖拖拖 --H5 拖放 API 基礎篇 - 前端 - 掘金不要搞錯,本文不是講如何拖地的。看過《javascript精粹》朋友應該知道,他實現拖放的過程比較復雜,現在時代不同了,我們用H5的新的拖放API就能非常方便的實現拖放效果了。最近在園子見...
閱讀 1398·2021-11-22 15:11
閱讀 2842·2019-08-30 14:16
閱讀 2760·2019-08-29 15:21
閱讀 2918·2019-08-29 15:11
閱讀 2459·2019-08-29 13:19
閱讀 2988·2019-08-29 12:25
閱讀 422·2019-08-29 12:21
閱讀 2836·2019-08-29 11:03