TS 项目 | 1 面试 | 2 面试题 | 3 面试+分析题 | 4 面试+分析题
Vue项目上线做的基本优化 -全 | 对于插槽的理解-文在最后面
> del /f/s/q node_modules > nul
> rmdir /s/q node_modulesAnimate css动画 | 掘金-‘正则’等工具函数 | 集合-快速处理数组
-
(1)、用
CompressionPlugin来处理 gzip 压缩。配合 nginx 开启gzip_static on;,开启之后 Nginx 会优先使用我们的 gz 文件。 -
(2)、处理结果:浏览器文件请求的请求头包含字段
Accept-Encoding: gzip代表浏览器支持 gzip 压缩文件。 -
(3)、处理结果:文件响应头包含字段
Content-Encoding: gzip代表返回的是压缩文件。
CDN 的全称是 Content Delivery Network,即内容分发网络。CDN 是构建在网络之上的内容分发网络,依靠部署在各地的边缘服务器,通过中心平台的负载均衡、内容分发、调度等功能模块,使用户就近获取所需内容,降低网络拥塞,提高用户访问响应速度和命中率。
CDN 存在的意义:为了不让网络拥塞成为互联网发展的障碍;
核心原理:将 webpack 中最耗时的loader文件转换操作任务,分解到多个进程中并行处理,从而减少构建时间。
(1) thread-loader(webpack4 官方推荐)
注意,当项目较小时,多进程打包反而会使打包速度变慢。
可以看到每个 loader 和插件执行耗时,重点的关注耗时较长的 loader 或插件,针对这些做优化。
- General output time took -一般输出时间
自带的JS压缩插件是单线程执行的,而 webpack-parallel-uglify-plugin 可以并行的执行
- (1)下载包
npm install swiper vue-awesome-swiper --s
- (2)main.js 全局引入
import VueAwesomeSwiper from 'vue-awesome-swiper';
import 'swiper/css/swiper.css';
Vue.use(VueAwesomeSwiper);
- (3)处理不同分辨率的盒子
swiperOption: {
breakpoints: {
//当宽度大于等于320
320: {
slidesPerView: 1,
spaceBetween: 10
},
//当宽度大于等于480
480: {
slidesPerView: 2,
spaceBetween: 30
},
1020: {
slidesPerView: 3, // 盒子数量
spaceBetween: 30 // 间距
}
}
},