项目优化

一,本文分为两部分
1.普通项目优化
2.vue项目优化
防止XSS与XSRF(安全性)
二,普通项目优化:
1.页面加载阶段
2.页面渲染阶段
一、 页面加载
dns预解析
使用cdn
静态资源的压缩与合并
减少https请求
异步加载defer,async
服务端渲染ssr
多使用内存和缓存
二、 页面渲染
css放前面,js放后面
减少dom查询,多次使用的保存为变量
减少dom操作,统一通过dom片段操作
事件函数的节流和防抖
图片懒加载
尽早进行操作, domcontentload与load
三、vue项目优化:
代码层面优化
webpack层面优化
web层面优化
一、代码层面优化
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
二、webpack层面优化
去除无用代码treeShaking.
babel编译es6到es5的时候,会有多余代码产生
减小app.js的体积,提取公共代码
减少vendor.js的体积,通过按需引入第三方库,或者有些资源可以通过script标签引入
代码切割,有一些组件没必要都打包到一起。
使用chunck
使用SouceMap,来还原线上代码,更方便的去定位线上问题
构建结果,通过可视化插件,进行分析
webpack对图片进行压缩等处理,
图片可以使用webp,优雅降级处理
编译优化
模板预编译,使用vue-template-loader,把模板编译成渲染函数。
三、web层面优化
浏览器缓存的使用
开启gzip压缩
CDN的使用,减少路由转发的次数,就近访问资源
使用chrome的性能分析工具,查找性能瓶颈
dns预解析
静态资源的压缩与合并
减少https请求
异步加载defer,async
静态资源和服务不要放在同一台机器上。多个域名去并行加载解析
四、安全性
基本后端来做,防注入等

@两种

  1. XSS跨站请求攻击,

输入时,插入一段脚本,来获取用户信息的cookie

  1. XSRF跨站请求未伪造,比如支付请求成一个图片请求,当然现在都没有这种的

@解决方案:

1.XSS 前端替换关键字,建议后端也替换,如<>的替换,避免脚本的执行

  1. XSRF增加验证流程,比如输入密码,指纹,短信验证码,人脸识别等
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,137评论 6 511
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,824评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,465评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,131评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,140评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,895评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,535评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,435评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,952评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,081评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,210评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,896评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,552评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,089评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,198评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,531评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,209评论 2 357

推荐阅读更多精彩内容

  • 前言 Vue 框架通过数据双向绑定和虚拟 DOM 技术,帮我们处理了前端开发中最脏最累的 DOM 操作部分, 我们...
    咸小七阅读 388评论 0 2
  • 1. 从用户角度而言,优化能够让页面加载得更快、对用户的操作响应得更及时,能够给用户提供更为友好的体验。2. 从服...
    刘松阳阅读 1,057评论 0 0
  • 普通项目优化 页面加载阶段 页面渲染阶段 一、 页面加载 dns预解析 使用cdn 静态资源的压缩与合并 减少ht...
    瀡風阅读 99评论 0 1
  • vue 项目我们一般都是使用脚手架去配置项目的,在项目开发过程和发布过程我们只需要做大自然的搬运工,但是上线的项目...
    颖哥ying阅读 508评论 1 1
  • vue项目优化方案(性能,包体积,页面加载速度等) 项目优化,是一个老生常谈的问题。这里简单总结一下相关方法: 1...
    东扯葫芦西扯瓜阅读 1,109评论 0 1