Sciwork开发日志:架构

结论

经过一段时间的考量,sciwork的前端架构规划是:

  1. 交互:React+Redux
  2. Ajax: Fetch+Promise
  3. 模板:DotJs
  4. 打包管理:Gulp+Webpack
  5. 单元+白盒测试:Mocha
  6. CSS:LESS
  7. 兼容性:Babel
  8. 语法规范检测:ESLint

后端的架构比较简单:

  1. NodeJS+Promise作为路由处理逻辑
  2. Mongoose作为数据库
  3. Redis做为缓存
  4. RPC+Kafka消息队列

其他的辅助功能:

  1. 用于Markdown文档编辑与渲染的控件,优选stackedit
  2. 用于搜索的后台服务,第三方或者java的elasticsearch
  3. CDN内容更新与部署,采用python
  4. 支付接口,暂时不考虑,后期采用独立接口

写在前面的废话

作为一个后端和移动端的开发者,有时候我会对前端出现的这么多的框架,插件,和工具感到非常惊讶。现在的软件开发,MVC / MVVM,异步操作,依赖,打包,测试已经是开发者所需掌握的标配,而这些概念在前端领域却是近几年材逐渐普及开的开发思想。早期的网页设计人员甚至都不能被称为工程师,而更多被叫做美工,切图的,只会做html和css编写真的和程序开发没什么关系。直到动态网页技术web2.0出现之后,前端开发才真正出现了程序的雏形。移动应用的出现为网页带来了更多的交互内容,换句话说,也就是为页面的操作逻辑带来了复杂的逻辑。可以想象,如果网页内容继续保持文本形态,那么在其之上的交互操作将变得异常复杂和低效率。无论是后来的MVC还是MVVM框架,所在尽力解决的问题就是将传统的文本形态的网页变成一个可以操作的对象。

这实际上也是前端向编程开发靠拢的一个过程,而这个过程因为javascript的天生权限和浏览器本身的定位,而变得异常繁复。

关于jQuery

早期的前端真的是很简陋,能用上jquery对前端已经是很大的突破了。jQuery出现的意义在于它让操作DOM成为可能。实际上,大部分的前端应用使用jQuery已经足够了,但是为什么我们还需要各种框架呢?这个问题没有标准答案,你可以说因为更好的轮子值得被使用。

为什么要上框架

框架存在的意义就是隐藏更多的DOM操作,让前端的交互以更直观的形式被实现。

1. 框架

框架的选择其实不多,react,angular,vue

其他使用度较小的框架,ember,backbone,jquery(是的,jquery已经不被频繁使用了)

事实上框架的选择并没有你所想的那么复杂,框架的作用无非是更好地完成DOM的交互控制

2. 异步

异步是为了解决javascript的单线程的多任务串行处理,ajax是异步的网页加载机制,promise和async是解决多任务执行与结果跟踪

3. 模板

模板可以用来替代后端页面渲染。传统JSP负责的view presentation可以部分被模板替代。

4. CSS模块化

用LESS,SASS把CSS进行参数化,目的是为了节省CSS的开发时间,避免重复的参数设置

5. 打包

gulp+webpack,gulp是一个通道,负责定义各种打包的任务,具体的活需要webpack来做

6. 测试

前端的测试一般分为两种,单元测试和自动化测试,后者的测试方式很难量化,和其他的GUI程序类似,前者的测试比较简单,用Mocha就可以实现软件开发常见的assert单元测试和白盒测试

7. 兼容

react使用了JSX,angular使用了ES6,两种语言在大部分浏览器中是不支持的,所以需要转译,我们采用Babel

8. CommonJS

CommonJs 是一种规范,目前可以不去关注

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

推荐阅读更多精彩内容