摘要:所以前端使用压缩是没有起作用的。影响,选项显示警告在删除没有用到的代码时不输出警告删除所有的语句还可以兼容浏览器内嵌定义了但是只用到一次的变量提取出出现多次但是没有定义成变量去引用的静态值此方法有待实践,留待下次分享
单页应用会随着项目越大,导致首屏加载速度很慢!!!以下给出在下知道的几种优化方案
使用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 // }),
此方法有待实践,留待下次分享 ==
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/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就能非常方便的实现拖放效果了。最近在园子见...
阅读 1346·2021-11-22 15:11
阅读 2809·2019-08-30 14:16
阅读 2725·2019-08-29 15:21
阅读 2883·2019-08-29 15:11
阅读 2427·2019-08-29 13:19
阅读 2956·2019-08-29 12:25
阅读 389·2019-08-29 12:21
阅读 2778·2019-08-29 11:03