一,本文分为两部分
- 普通项目优化
- vue项目优化
- 防止XSS与XSRF(安全性)
二,普通项目优化:
1、 页面加载
- dns预解析
- 使用cdn
- 静态资源的压缩与合并
- 减小https请求
- 异步加载defer,async
- 服务端渲染ssr
- 多使用内存和缓存
2、 页面渲染
- css放前面,js放后面
- 减小dom查询,屡次使用的保存为变量
- 减小dom操做,统一经过dom片断操做
- 事件函数的节流和防抖
- 图片懒加载
- 尽早进行操做,domcontentload与load
3、vue项目优化:
- 代码层面优化
- webpack层面优化
- web层面优化
1、代码层面优化
- Object.freeze(data);对于一些查询类的页面,调取接口回来后的数据可不进行数据劫持
- v-if和v-for不要在一块儿使用。v-if的条件经过函数来处理
- v-for中加上key,对于虚拟dom树查找提升性能
- computed和watch注意区分使用场景。前者是有缓存的。后者是监听到数据变化后的回调无缓存
- created中发起请求,mounted钩子中表明页面dom加载完成能够进行dom操做。
- 长列表性能优化,只渲染可视区域的列表
- 长表格性能优化,经过canvers来绘制表格
- 合理使用$nextTick去操做dom,适用于更新了数据立刻就要操做dom的场景
- 操做dom不要使用js原生的方式来操做。用vue提供的三种方式来操做 好比,ref、自定义指令el、事件中的话用e.target获取dom
- 尽可能不要在前端进行大量的数据处理
- 合理使用keep-alive来缓存页面数据,跳过created,mounted钩子,他有本身特定的钩子activted等
- 路由懒加载经过import配合箭头函数,还有其余的方式require
- 组件懒加载,异步加载
- 尽可能少用float,能够用flex布局
- 频繁切换的使用v-show,不频繁的使用v-if
- 不要在模板中写过多的样式
- 服务端渲染ssr,优化seo,与首屏白屏问题。
- 经过addEventListenr添加的事件,须要自行销毁
- 把组件中的css提取成单独的文件
- 少使用闭包与递归,递归可作尾递归的优化
- 使用字体图标或者svg来代替传统的Png等格式的图片
- 在Js中避免“嵌套循环”和“死循环”
- 尽量的使用事件委托来处理事件的绑定,针对老项目jq
2、webpack层面优化
- 去除无用代码treeShaking.
- babel编译es6到es5的时候,会有多余代码产生
- 减少app.js的体积,提取公共代码
- 减小vendor.js的体积,经过按需引入第三方库,或者有些资源能够经过script标签引入
- 代码切割,有一些组件不必都打包到一块儿。
- 使用chunck
- 使用SouceMap,来还原线上代码,更方便的去定位线上问题
- 构建结果,经过可视化插件,进行分析
- webpack对图片进行压缩等处理,
- 图片可使用webp,优雅降级处理
- 编译优化
- 模板预编译,使用vue-template-loader,把模板编译成渲染函数。
3、web层面优化
- 浏览器缓存的使用
- 开启gzip压缩
- CDN的使用,减小路由转发的次数,就近访问资源
- 使用chrome的性能分析工具,查找性能瓶颈
- dns预解析
- 静态资源的压缩与合并
- 减小https请求
- 异步加载defer,async
- 静态资源和服务不要放在同一台机器上。多个域名去并行加载解析
4、安全性
基本后端来作,防注入等css
@两种前端
1. XSS跨站请求攻击,
输入时,插入一段脚本,来获取用户信息的cookievue
2. XSRF跨站请求未伪造,好比支付请求成一个图片请求,固然如今都没有这种的webpack
@解决方案:es6
1.XSS 前端替换关键字,建议后端也替换,如<>的替换,避免脚本的执行web
2. XSRF增长验证流程,好比输入密码,指纹,短信验证码,人脸识别等。chrome