模块化思路|学习笔记

简介: 快速学习模块化思路

开发者学堂课程【Node.js 入门与实战模块化思路】学习笔记,与课程紧密联系,让用户快速学习知识

课程地址https://developer.aliyun.com/learning/course/588/detail/8301


模块化思路


目录:

一、模块化思路

二、示例

三、代码模块化

 

一、模块化思路

让代码模范化:便于代码的使用开发和后期代码的维护

多人协作的条件:代码最好分开几个文件放置,最好每个功能一个文件,每个人负责一个功能修改哪个文件即可。

 

二、示例

// 1.读取 data.json 文件的数据

readNewsData(function(list) {

// 2.

// 在把新闻添加到 list 之前,为新闻增加一个id属性url0bj.query.id = list.length;

//向数组对象 list 中 push 一条新闻

list.push(url0bj.query);

// 3.写入 data.json 文件

writeNewsData(JS0N.stringify(list),function() {

//重定向

res.statusCode = 302;

res.statusMessage . 'Found';

res.setHeader('Location''/');

res.end();

});

});

} else if (reg.url *** '/add' && req.method ***'post') { 

// 1. 读取 data.json

readNwsData(function(list) {

// 2.读取用户 post 提交的数据

postBodyData(req,function(postData) {

// 3.为用户提交的新闻增加一个 id 属性,并且把新闻对象 push 到list中postData.id = list.length;

list.push(postData);


三、代码模块化

1、代码模块一

//1.加载 http 模块

//模块改造的核心思想就是把项目中按照功能模块,不同代码提取到不同JS文件中

//index.js 只负责启动服务,定义为模块一

var http = require('http');

var fs = require('fs');

var path = require('path');

var mime = require('mime');

var url = require('url');

var querystring =require('querystring');

var_ = require('underscore');

// 2.代码模块二

2.创建服务

//模块二对 res 和 req 进行扩展服务,为 req 和 res 增加以下更方便好用的 API

http.createServer(function(req,res) {

//要在这里写大量的代码

//为 res 对象添加一个 render() 函数,方便后续使用

//因为现在要渲染的 index.html 中需要用到模板数据,所以给render函数增加了第二个参数

//第二个参数的作用就是用来传递 html 页面中要使用的模板数据

res.render = function(filename,tpLData)//增加一个render函数就是为了后期使用方便,并且渲染时和特定业务无关,其他业务涉及渲染时也可以使用 render 函数.

{

fs.readFile(fllename, function(err,data) {

if (err) {

res.writeHead(404,'Not Found',{'Content-Type':'text/html;charset=utf-8' });

res.end('4B4,not found.');

return;

}

//如果用户传递了模板数据,那么就使用 underscore 的 template 方法进行替换“

//如果用户没有传递模板数据,那么就不进行替换

1f (tplData) {

//如果用户传递了模板数据,表示要进行模板

var fn = template(data.toString('utf8'));

data = fn(tp1Data);

}

res.setHeader('Content-Type',mime.getType(filename));

res.end(data);});

3.代码模块三

模块三路由判断

将用户请求的 url 和 method 转换为小写字母 req.url = req.url.toLowerCase();

req.method = req.method.toLowerCase();

通过 url 模块,调用 url.parse() 方法解析用户请求的 url (req.url)

var url0bj = url.parse(req.url,true)

//先根据用户请求的路径(路由),将对应的HTML页面显示出来

if  (req.url ·***·/’·req.url·***./index’·&&·req.method·***·get){

4. 代码模块四

模块四处理具体路由的业务的代码

//1.读取 data.json 文件中的数据,并将读取到的数据转换为list数组

readNewsData(function(list)){

//2.在服务器使用模板引擎,将 list 中的数据和 index.html 文件中的内容结合渲染给客户端

res.render(path.join(_ _dirname,views,index.html),{list:list});

});

} else if(req.url *** /submit&& req.method *** get){

//读取 submit.html 并返回

res.render(path.join(_ _dirname,views,submit.html));

}

else if (url0bj.pathname === /item&& req.method === get){

//1.获取当前用户请求的新闻的 id

//url0bj.query.id

//2.读取 data.json 文件中的数据,根据 id 找到对应新闻

}

}

相关文章
|
2月前
|
算法 测试技术
模块化设计具体应该怎么做呢
【10月更文挑战第22天】模块化设计具体应该怎么做呢
|
前端开发
前端学习案例1-模块化1
前端学习案例1-模块化1
72 0
前端学习案例1-模块化1
|
前端开发
前端学习案例2-模块化2
前端学习案例2-模块化2
62 0
前端学习案例2-模块化2
|
前端开发 JavaScript NoSQL
DDD实战之二:看看代码结构长啥样
DDD实战之二:看看代码结构长啥样
DDD实战之二:看看代码结构长啥样
|
前端开发 JavaScript 开发者
前端技术-模块化概念说明 | 学习笔记
快速学习 前端技术-模块化概念说明
108 0
|
设计模式 安全 测试技术
经验总结 | 重构让你的代码更优美和简洁
最近,笔者有幸对高德打车订单Push项目进行了重构,与大家分享一下代码重构相关的工作经验,希望对大家有所启发。
249 1
经验总结 | 重构让你的代码更优美和简洁
|
前端开发 测试技术
前端测试代码怎么做抽象?
哈喽,大家好,我是海怪。 不知道大家在写前端单测的时候,是否有出现测试代码和测试数据重复冗余的情况?然后不得不写一些函数和类来封装他们的。然而,慢慢地会发现:过度的封装会致使你的测试用例变得越来越难读。 那到底在写测试代码时,怎样的封装才是好的封装呢?今天就把 Kent 的这篇 《AHA Testing》 分享给大家~
前端测试代码怎么做抽象?
|
前端开发
前端也要学习基本的UI设计原则与实践套路
有的人可能说,我是技术研发人员,UI的事情我们团队内会有别的人去操心这个,我只管技术即可。 在一天之前,我也是这么觉得的,但是我前些日子听了字节的《给开发看的UI设计》这节课后,觉得一个前端工程师也是要具备一定的UI设计能力的。 依赖市面上的组件库已经不能让产品维持在好用的状态了,还需要将一些设计元素添加进去,才能让我们开发的作品,达到一个更好的层次,给与用户最好的体验。 你的团队可能没有UI同学,也可能有UI同学,但是不一定专业,他们经常会是外包人员,UI给出的设计稿通常只是静态文件,是某一交互切面的,很多的交互细节都体现不出来,在大厂中,许多的B端产品是没有专职UI角色的,前端可能要
|
Java C# C++
面向过程的程序的开发思路
面向过程的程序的开发思路
164 0
|
数据库
高质量代码优化!谈谈重构项目中if-else代码的几点建议
本篇文章探讨了代码的重构以及优化,主要针对代码中大量的条件判断if-else语句问题提出了具体的优化建议。介绍了优化if-else语句的几种有效的方法,包括switch,接口interface以及数据库实现对条件语句进行的优化。
184 0
高质量代码优化!谈谈重构项目中if-else代码的几点建议