node.js 学习第四节 业务逻辑

尽管上次交的作业(想想都是好几个星期前的事了)--学习数据建模,其实是没有真正理解的,这几周我反复看教程和项目中的代码组织架构,似乎能明白一些了,再补充一些自己的理解。
我们要搭建的后台项目文件是以MVC的模式来进行组织的。
M--表示模型,组织数据和程序的功能
V--表示视图,用于处理和用户的交互
C--表示控制器,负责将视图请求转化给对应的模型

具体在我们学习的项目--实现图片交换功能里,比如通过evergrow 脚手架一键生成的model文件,通常都包含四个文件:

yo evergrow:model user
user-controller.js
user-manage.js
user-model.js
user-routes.js

yo evergrow:model Image
image-controller.js
image-manage.js
image-model.js
image-routes.js

从这四个文件我能理解就已经包含了 MVC 中的 MC ,而这个 M 老师的教程中说不仅仅包含数据模型,还包括数据处理,即业务逻辑部分。那对应的就是〜-model.js与~-manage.js这两个文件模块。那这个 C 对应的就是 ~-controller.js 和~-routes.js 这两个文件模块。
只是我也好奇,为啥 MVC中的 V 它还得单独一键生成不一样的四个文件,

yo evergrow:view Image
view/image/imageList.html
view/image/imageProfile.html
public/js/image/imageList.js
public/js/image/imageProfile.js

由于这个视图部分涉及到显示给用户的界面如html , css , js 等这些前端的内容,表示还没看懂,还得努力学!

理解了以上这些大致的架构,对于教程中一节一节的内容感觉就容易些了。

第一部分 业务逻辑

这一节,我主要记住,业务逻辑代码的组织结构和规律。
具体解析image-manager.js这个模块里的代码。


屏幕快照 2017-06-13 下午9.54.11.png

在解析代码之前,要特别强调一下老师教程中的这段话,值得反复读:

其实,写代码和搭乐高积木差不多。代码的一个变量,一个函数,可以看作是一个乐高的最小元件。每一个 JavaScript 文件,就像是乐高的一个小人,小车或小屋。最后我们实现的整个 Node.js 项目,就是整个宏大的乐高场景。
我们引用模块其实和寻找合适的积木是一样的。通过把自己写的,别人已经拼好的,进行恰当的组合,就可以完成千变万化的作品。

因为这段话,我明白了为啥要 require()那么多东西,也明白了干嘛要写这么多~.js文件,它们到底要干嘛!好的类比真的好伟大!

正式进入代码解析

  • 上面代码的前三句是模块引用。有全局模块 lodash (一套工具库)和项目本身的 image-model 和 db-manager。项目本身的模块以文件相对路径来引用,全局模块就只需要名字。
  • module.exports={} 里封装的就是 image-manager.js 这个文件模块要申明的功能,这些功能包括最基础的 CRUD数据操作,create (C - Create), load (R - Read), update (U - Update), remove (D - Delete) 和 list (批量 Read)。
  • function(){} 部分就是 module.exports={} 里申明的方法的具体实现办法,一个方法对应一个相同名称的函数。
  • 这意味着如果要修改或添加某个功能,上述代码的三个部分可能都需改动,起码得改动两个部份。
  • 教程中的两个功能实操代码,看是看明白了,只是老师布置的作业,写个 reject 的方法并导出,没理解这个reject 的业务要求是 什么,是要拒绝什么?是用户新创建的图片,没审核通过的拒绝被返回?不对呀,没明白,还得请教老师!
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,444评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,019评论 4 62
  • 沈从文笔下的《边城》让我们知道了‘凤凰古城’,与凤凰古城相聚不远的地方,有一个里耶古城。这样一个美丽的地方。在凤凰...
    绿芒果君阅读 671评论 0 0
  • 两个月前,在金华一家美发店当吹头小哥的20岁小伙子陈飞雄,被网友拍了一组照片放到网上,瞬间爆红,仅仅两个月时间,他...
    娱观阅读 138评论 0 0
  • 听着妈妈均匀的呼吸 确定妈妈睡着了 就像小时候妈妈哄我一样 等我睡着了 再去纳一双鞋底 安静的夜里 别人家的灯仍然...
    扫云阅读 453评论 0 2