前端重构方案

来源:吃葡萄不吐番茄皮

segmentfault.com/a/1190000014753304


前言

前端技术发展很快,很多项目面临前端部分重构,很开心可以让我进行这次项目前端的重构方案编写,在思考的同时参考了网上很多资料,希望本篇重构方案有一定的完整性,可以带给大家一些在面临重构时有用的东西,同时希望路过的大牛小牛不领赐教,能给我略微指点下重构相关的点,在下感激不尽~


一、原项目梳理

首先对原来项目做一个大概的梳理,既然是重构,当然很多东西是可以继续拿来使用的。


1.1页面结构


我这边负责的PC端的重构,所以先把页面结构及之间的关系梳理了一遍,并用xmind画好结构图,重点功能做上标记,因为vue是渐进式框架,所以我会优先重构重要的部分


xmind结构图我就不上了,职业操守还是要的


1.2项目结构

项目结构是针对代码组织结构的,梳理了项目各重要的文件夹及文件并注明对应的内容或者作用。同样的,使用xmind画出结构图,xmind图略。


1.3前端框架、模板

使用公司内部人员自创框架C.F.F,自定义build文件,内嵌Smarty模板获取后台数据,利用{$xxx}获取后台数据,但是定义了很多全局变量存储模板数据,造成占用更多内存、污染命名空间等问题。


定义公共组件供各模块或特定场景调用,复用度高


1.4第三方库、组件、插件

1、jquery: JavaScript库

2、html5shiv:用于解决IE9以下版本浏 览器对HTML5新增标签不识别,并导致CSS不起作用的问题。

3、Dialog : jquery弹窗插件

4、jCarousel : jquery 轮播插件 (重构版舍弃,原因不复杂的场景能原生实现尽量原生实现)

5、respond:为 IE6-8 以及其它不支持 CSS3 Media Queries 的浏览器提供媒体查询的 min-width 和 max-width 特性,实现响应式网页设计

6、sideToolbar:导航工具

7、echarts: 图形工具

8、...


二、重构方案

2.1开发规范


1、命名规范

2、html/css/less/sass/scss/javascript编码规范

3、代码检查工具 eslint


规范这个东西没有绝对的对错,只有同公司或者同部门来制定规范大家都保持一致,同事之间能很快读懂相互的代码,提高开发效率


2.2技术选型


2.2.1 开发模式:前后端分离


前后端分离开发早已成为趋势,到现在新项目大多采用这种模式进行开发,项目完全重构的话当然首选此模式


好处:以前没有前端这一职位之说,都是后端兼顾开发,数据库、底层服务、接口,页面一把梭,压力大,而且精力有限不能在每个领域都做的出色。后来有切图这一职,可以把页面写的更精美一些,通过模板和请求接口配合进行数据交互,前端都是紧紧耦合于后端,这种情况下开发,沟通成本,开发过程中进度依赖成本都是较高的。前后端分离后,分工更明确,各自专注做好自己领域的事,同时开工,不相互依赖,效率高


原理:(此图来自某博客,地址忘记。 望博主看到能联系我加上转载出处,在此抱歉~)



开启一个本地的服务器来运行自己的前端代码,以此来模拟真实的线上环境;

利用nodejs的express框架来开启一个本地的服务器,然后利用nodejs的一个http-proxy-middleware插件将客户端发往nodejs的请求转发给真正的服务器,让nodejs作为一个中间层。

然后就是数据问题了,后端接口在开发中,前端需要数据怎么办呢?mockjs了解一下,

API地址https://github.com/nuysoft/Mo... ,当后端设计出AP接口文档后,我们就可以利用mockjs模拟出对应格式的假数据进行开发,等到接口完全完成之后,再进行接口联调


2.2.2 MVVM框架:vue


Vue是一个渐进式框架,容易入手、容易协同,能够快速灵活的开发迭代。同时也是目前主流三大框架里学习成本最低的,目前,公司也在主推vue作为首选框架,进行相关技术的培训。 


Vue社区相对热度高,组件、库、轮子多,资源整合链接(https://segmentfault.com/p/1210000008583242/read?from=timeline#UI%E7%BB%84%E4%BB%B6)


体积小、自由度高、脚手架创建的项目自带webpack打包构建工具

虽然vue是单页应用,但是可以通过配置webpack进行多页开发


2.2.3 css预编译语言


使用css预编译语言来写css会提高编写css效率(具体提高多少百分比效率可自行测试,我觉得找一段写好的css,先用css写一遍,再用less或者其他写一遍计算耗时百分比,这里忽略写样式时候思考的时间进行测试)


预编译语言可以定义变量(比如常用的颜色、字体、字号等)、嵌套写法、可以继承其他类的属性、计算、内置函数等


2.2.4 常用类库


1、图形工具—echarts (对应场景 – xxx)

2、适配插件—flexible taobaoH5终端适配方案 (对应场景—xxx)

3、Lodash – JS函数库 (对应场景—xxx)

4、ElementUI – UI库 (对应场景—xxx)

5、One-Page-Nav – 导航插件 (对应场景—xxx)


具体场景我就不写了,根据你们不同的业务需求去判断需要哪些类库插件之类的,预先决定好,以免半途做什么都要去花时间思考


2.3构建工具


既然选择了vue框架,构建工具当然选择vue自带的webpack了,对于webpack有人说会配置项目就行,有人说要深入研究,这个看个人需求我觉得


2.4开发效率


1、PS一键切图功能

2、emmet快速编写HTML


#page>div.logo+ul#navigation>li*5>a{Item $}


按下tab键,上述代码 等于


<div id="page">
   <div class="logo"></div>
   <ul id="navigation">
       <li><a href="">Item 1</a></li>
       <li><a href="">Item 2</a></li>
       <li><a href="">Item 3</a></li>
       <li><a href="">Item 4</a></li>
       <li><a href="">Item 5</a></li>
   </ul>
</div>


背景:原项目写的纯css


less/sass/scss 快速编写css

比如


@base-size: 40px;
@theme-color: #ccc;
@my-selector: title;
.aa {
 font-weight: bold;
}
.@{my-selector} {
 font-size: @base-size;
 color: @theme-color;
 margin: 100/2px 200/10px;
 &-ok {
   color: green;
 }
 &-no {
   color: yellow;
 }
 > li{
   &:extend(.aa);
   &:hover {
     color: #fff;
   }
 }
}


编译后为:


.aa,
.title > li {
 font-weight: bold;
}
.title {
 font-size: 40px;
 color: #ccc;
 margin: 50px 20px;
}
.title-ok {
 color: green;
}
.title-no {
 color: yellow;
}
.title > li:hover {
 color: #fff;
}


这里只写了一点点,功能还有很多的

less官网(https://less.bootcss.com/features/)

sass官网(https://www.sass.hk/)


1、webpack:压缩代码、图片,合并JS,检测文件更新等自动进行

2、webstorm自带取色器(其他IDE应该都有,自行找下)


写颜色色值的地方可以点击调出取色板(不限于css),可以选颜色也可以利用吸管取色(屏幕任意处 不限于IDE内部),也有取色的网站可以收藏到书签工具文件夹里



Mockjs:上面有介绍mockjs,这里不再赘述,由于本人有过手写假数据的悲惨经历,故把mockjs列入可以提高开发效率行列,因为前后端分离后前后端同时开发,假数据已成必须


比如:


let template = {
   'anchorList|3-6':[{
     'id|1-100': 1,
     'name': '@cname',
     'date': '@date(yyyy-MM-dd)',
     biubiubiu: () => Mock.Random.string('abcdefghijklmnopqrstuvwxyz', 5),
     'arr|2-5': [{
       'age|10-20': 0
     }]
   }]
 }
 console.log(Mock.mock(template))


输出:



模块化、组件化开发:前后端解耦后,前端之间配合也可以解耦,各自负责不同的模块开发,写自己的组件,最后通信部分再协同


2.5性能优化


2.5.1 数据存取


☆ 尽量使用局部变量

☆ 对象成员的嵌套深度与读取时间成正比,嵌套过深要进行优化


2.5.2 DOM


☆ 尽量减少DOM操作(访问和修改都算)的次数

☆ 访问元素时使用最快的API

☆ 使用事件委托来减少事件处理器的数量

☆ 减少重绘和重排的次数


2.5.3 算法和流程


☆ for循环、while循环、do-whild循环比for in 要快

☆ 优化循环体的复杂度

☆ 最小化属性查找:


for(let i = 0, len = arr.length; i < len; i++){
...
}


☆ 当条件较少时 使用if-else更易读,而当条件较多时if-else性能负担比switch大,易读性也没switch好。

☆ 对于if else 概率越大的条件越靠前判断 比如:


☆ 当计算量很大且重复的时候,用Memoization缓存计算结果


2.5.4 字符串拼接


比较下四中字符串拼接方法的性能:

A:str = str + 'a'+'b'

B:str += 'a' + 'b'

C: arr.join('')

D:str.concat('b','c')

☆ Chrome65上测试的是A优于B优于C优于D


其他浏览器不确定


2.5.5 Ajax


☆ 服务端设置HTTP头信息确保响应会被浏览器缓存

☆ 客户端讲获取的信息存到本地避免再次请求(localstorage sessionstorage cookice)

☆ 设置HTTP头信息,expiresgaosu告诉浏览器缓存多久

☆ 减少HTTP请求,合并css、js、图片资源文件等或使用MXHR

☆ 通过次要文件用Ajax获取可缩短页面加载时间


这里只列了比较重要的一部分,安利一下我之前写的性能优化总结传送门


2.6模块化组件化


模块化:以前由CommonJs、AMD、CMD等实现,现在ES6的Module(原生模块化)完全可以取而代之,灵活、高效是模块化开发的好处,对于某个模块我想输出就输出,想引入就引入,输出引入也只需一个关键词(export/import),而且ES6模块语法支持暴露常量、单一接口、所有接口、混合暴露、取别名等等灵活高效是毋庸置疑的


配合webpack在构建的时候把资源整合打包压缩自动处理了一些以前需要手动进行的性能优化问题了 


组件化:解决复杂业务的痛点,把复杂的业务分为很多个组件分开开发管理以降低开发难度和维护成本。一个5000行的页面和十个500行命名规范的组件哪个开发、维护简单?


组件灵活随加随用,可复用避免重复开发,可组合使用


2.7前端安全


2.7.1 XSS


XSS是指浏览器错误的将攻击者提供的用户输入数据当做JavaScript脚本给执行了

解决办法:校验用户输入,特殊字符进行转义

Vue 双花括号自带过滤功能


2.7.2 本地存储数据泄露


本地存储的所有数据就都可能被攻击者的JS脚本读取到,所以敏感、机密信息都不建议在前端存储

const常量 let 块级作用域避免代码习惯不佳导致的作用域混乱问题


2.8用户体验


☆ 优化加载速度,减少用户等待时间

☆ 减少不必要的无谓的操作

☆ 动画交互合理,短平快的交互或者动画更适合知学宝,我们是功能型网站不是欣赏型网站,不需要太花里胡哨的动画,那样反而增加等待时间,适得其反

☆ 更赏心悦目的UI(字体、图片、logo,按钮、列表等)

☆ 处理好很多小的细节的地方,比如... 针对项目的地方就略了


关于用户体验这块暂时没找到比较权威的书,如果大家有觉得不错的欢迎留言推荐~


end

写的不是很细,但愿很多地方都覆盖到了,欢迎补充~

感兴趣的小伙伴,可以关注公众号【grain先森】,回复关键词 “vue”,获取更多资料,更多关键词玩法期待你的探索~

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

推荐阅读更多精彩内容

  • 前言 前端技术发展很快,很多项目面临前端部分重构,很开心可以让我进行这次项目前端的重构方案编写,在思考的同时参考了...
    一Left一阅读 1,033评论 0 0
  • Vue开源项目库 Vue.js开源项目速查表:https://www.ctolib.com/cheatsheets...
    cctN阅读 1,007评论 0 13
  • 上一章 2.偶遇秦总 3. 晚上7点,杨二狗和王若智准时来到盛皇大酒店门前。两人抬头看了看那气派的酒店大门, “...
    1019d835891a阅读 228评论 1 2
  • 180102《精进》,第八遍,分享框架构思 一,顺序:倒序讲。对照标靶模型,从中间的靶心,逐渐往外扩展。 二,分享...
    追追风的冰阅读 593评论 3 11
  • 爸爸在村里是个会计。 还记得我小时候,父亲白天干完农活,晚上就着煤油灯,坐在桌子前算账,我也坐在桌子前,写作业。 ...
    陈清伟阅读 1,490评论 0 2