Node填坑教程——整理文件
如果你能把所有代码写进一个文件,并且能很好的管理、协调、多人开发。那么可以跳过这期(请务必带我飞)。
我们接着完善上期的代码,给代码分家。
node并没有启动入口,更没有固定的项目结构,文件配置。这些全部要靠自己动手,靠约定,正所谓约定由于配置。因为作者书读的少,只会MVC结构,姑且按照MVC结构来分。
建立如下目录。
- /bin/ : 项目的启动文件,也可以放其他乱七八糟的脚本。如果你有多种环境或者多个入口,这样分就很有必要的
- /configure/ : 配置文件,上图中根据生产环境和开发环境配置了两个文件夹,分别是development和production
- /lib/ : js源代码,app.js文件也在这里
- /logs/ : 日志文件
- /node_modules/ : 通过npm包管理中间件都在这,包括session,模板,日志等中间件,你自己安装的中间件也在这
- /public/ : 暴露的文件夹,从名字就可以看出,图面前端js脚本和css会在这里
- /src/ : 其他语言的文件,如果是coffeescript的项目,编译前的文件会放在这里,编译后的文件在lib里,这里我们暂时用不到
- /test/ : 单元测试
- /views/ : 模板文件
- /app.js : 约定俗成的项目入口
- /package.json : 配置你项目依赖的包,使用npm命令 npm install -d 会自动安装里面记录的中间件,非常方便。由于nodejs的中间件不完全是脚本组成的,也会包含C写的编译文件,各环境下不尽相同,所以通过npm,本地下载编译是非常重要的
下面我们来填充文件
lib/app.js
var express = require('express');
var app = express(); module.exports = app;
bin/start.js
var app = require('../lib/app'); var port = 3000;
var server = app.listen(port, function () {
console.log('http server listening on port %s', server.address().port);
});
这里bin/start.js充当程序的启动文件。通过node bin/start.js启动项目。现在访问http://127.0.0.1:3000/能看到Cannot GET /的字样就说明成功了。
我们来写第一个路由
controllers/homeController.js
var action = {
get: function (req, res, next) {
return res.send('ok');
} }; module.exports = action;
routes/homeRoute.js
1 var express = require('express');
2 var controller = require('../controllers/homeController');
3 var router = express.Router();
4
5 router.get('/', controller.get);
6
7 module.exports = router;
routes/index.js
var homeRoute = require('./homeRoute');
module.exports = function (app) {
app.use(homeRoute);
}
routes/app.js
var path = require('path');
var express = require('express');
var route = require('./routes');
var bodyParser = require('body-parser');
var app = express(); app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true })); route(app); module.exports = app;
现在第一个路由已经配置好了,访问 http://127.0.0.1:3000/ 就能看到ok的提示。
接下来我们添加一个能交互的页面。
首先我们需要一个模板引擎,使用npm安装
E:\project\heron-lesson\demo3>npm install ejs --save
修改app.js文件
var path = require('path');
var express = require('express');
var route = require('./routes');
var bodyParser = require('body-parser');
var app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
app.set('views', path.join(__dirname, '../views'));
app.set('view engine', 'ejs');
app.engine('ejs', require('ejs').renderFile);
route(app); // 路由文件分开 module.exports = app;
由于我们还没讲到数据库,那么先缓存几个数据吧
controllers/listController.js
var data = [
{name: '张三', age: 20},
{name: '李四', age: 22}
];
继续填充路由
var action = {
index: {
get: function (req, res, next) {
return res.render('list/index', {data: data});
}
}
}; module.exports = action;
routes/listRoute.js
var express = require('express');
var controller = require('../controllers/listController');
var router = express.Router(); router.get('/index', controller.index.get); module.exports = router;
routes/index.js,我们这里用了个小技巧给list路由加上了目录/list
var homeRoute = require('./homeRoute');
var listRoute = require('./listRoute');
module.exports = function (app) {
app.use(homeRoute);
app.use('/list', listRoute);
}
views/list/index.ejs
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>List</title>
</head>
<body>
<ul>
<% data.forEach(function (item) { %>
<li>姓名:<%= item.name %>,年龄:<%= item.age %></li> <% }) %>
</ul> </body>
</html>
现在访问http://127.0.0.1:3000/list/index ,就能看到两行数据了。注意,如果你输出的中文有问题,请更改你的代码文件,保存为utf-8。
姓名:张三,年龄:20
姓名:李四,年龄:22
我们再添加一个搜索功能
修改页面 /views/list/index.ejs
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>List</title>
</head>
<body>
<form action="" method="post">
搜索:<input type="text" name="q"/> <input type="submit"/>
</form>
<ul>
<% data.forEach(function (item) { %>
<li>姓名:<%= item.name %>,年龄:<%= item.age %></li> <% }) %>
</ul> </body>
</html>
同上controllers、routes都得改
controllers/listController.js
var data = [
{name: '张三', age: },
{name: '李四', age: }
]; var action = {
index: {
get: function (req, res, next) {
return res.render('list/index', {data: data});
},
post: function (req, res, next) {
var list = [];
data.forEach(function (item) {
if (item.name === req.body.q)
list.push(item);
});
return res.render('list/index', {data: list});
}
}
}; module.exports = action;
routes/listRoute.js
var express = require('express');
var controller = require('../controllers/listController');
var router = express.Router(); router.get('/index', controller.index.get)
.post('/index', controller.index.post); module.exports = router;
刷新页面。
就可以根据name字段来完全搜素了。
彩蛋:
每次都要修改routes里的多个文件来路由,是不是太麻烦了呢。
D:\project\heron-lesson\demo3>npm install heron-mvc
安装heron-mvc。github: https://github.com/iheron/heron-mvc
修改lib/app.js
var path = require('path');
var express = require('express');
var route = require('./routes');
var bodyParser = require('body-parser');
var app = express();
var mvc = require('heron-mvc'); app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
app.set('views', path.join(__dirname, '../views'));
app.set('view engine', 'ejs');
app.engine('ejs', require('ejs').renderFile); mvc.route.load({
routeDir: path.join(__dirname, './routes'),
controllerDir: path.join(__dirname, './controllers')
}, function (data) {
app.use("/" + data.route, data.router); // 优先加载路由
}, function (data) {
app[data.method]("/" + data.controller + "/" + data.action, data.func); // 没有路由直接加载控制器 会根据控制器的前缀和action名称 生成两级目录
}); module.exports = app;
现在是见证奇迹的时候了。不用再改routes 来处理路由了,甚至可以删除这个了。
该插件会根据controller的前缀和action的名称来自动生成两级目录。如果你要手动控制路由,也会优先加载路由配置。
该项目下载地址:demo3
下载后需通过npm install -d 来安装依赖
下一期如果内容过多会考虑录成视频。大家如果有什么想看的可以给我留言。
Node填坑教程——整理文件的更多相关文章
- Node填坑教程——前言
Node是什么? Node 是一个服务器端 JavaScript 解释器,它将改变服务器应该如何工作的概念.它的目标是帮助程序员构建高度可伸缩的应用程序,编写能够处理数万条同时连接到一个(只有一个)物 ...
- Node填坑教程——HelloWorld
环境安装(极简): Node需要的环境可以说及其简单,也可以说及其复杂.为什么这么说呢? 如果里只需要运行环境那么到Node官网下载一个包就行了.里面自带npm管理工具,这是包管理工具,以后会频繁的使 ...
- Node填坑教程——简易http服务器
我们这一期做一个简易的http服务器. 先建一个文件夹,就算是一个空的项目了.然后新建app.js和package.json文件. 这样一个简易项目的基本文件就建好了. 通过命令行工具,在项目路径下输 ...
- Node填坑教程——过滤器
所谓“过滤器”,只是一个概念,可以理解是一个路由,也可以理解为一个中间件.原理非常简单,就是利用匹配规则,让其有限匹配在正常的路由前面处理就行了. 比如有如下路由 app.get('/', funct ...
- Node填坑教程——常用库
作为函数式编程来说,流程控制和函数库是必不可少的(应该吧). 下面我们介绍两个常用的库. lodash:完整的api请参阅,https://lodash.com/docs.这里我们只演示几个简单的例子 ...
- Android项目开发填坑记-so文件引发的攻坚战
故事的最初 我负责的项目A要求有播放在线视频的功能,当时从别人的聊天记录的一瞥中发现百度有相关的SDK,当时找到的是Baidu-T5Player-SDK-Android-1.4s,项目中Demo的so ...
- ReactNative 从环境和第一个demo说起,填坑教程
一.React-Native MacOS必备环境配置: 1.安装homebrew(这东西可以理解为命令行的app商店) /usr/bin/ruby -e "$(curl -fsSL http ...
- backbone新手填坑教程资源
backbone 入门第二版 http://www.kancloud.cn/kancloud/backbonejs-learning-note/49379 backbone 入门讲解 http://w ...
- Vue3+Typescript+Node.js实现微信端公众号H5支付(JSAPI v3)教程--各种填坑
----微信支付文档,不得不说,挺乱!(吐槽截止) 功能背景 微信公众号中,点击菜单或者扫码,打开公众号中的H5页面,进行支付. 一.技术栈 前端:Vue:3.0.0,typescript:3.9.3 ...
随机推荐
- 看德日进,凯文·凯利与Kurzweil老师?
生命从哪里来.要到那里去.生命存在的意义是什么.这些差点儿是人类可以探究的最深层次问题.基督教给出的答案是毁灭和审判.佛学给出的答案是无常,科学的达尔文进化论给出了生命的起点和进化的过程,对于未来.达 ...
- 打造简易可扩展的jQuery/CSS3 Tab菜单
原文:打造简易可扩展的jQuery/CSS3 Tab菜单 今天我们利用jQuery和CSS3来打造一款简易而且扩展性强的Tab菜单,这款Tab菜单在切换时也有滑块的效果,先来看看效果图: 由与Tab菜 ...
- 我的MYSQL学习心得(一)
原文:我的MYSQL学习心得(一) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYSQL学习心得(五) 我的MYSQL ...
- 关联A850刷机包 高级电源 时间中心 优化 ROOT 动力 美化 简化
ROM简介 1.合并app以及framewok框架apk 2.破解安卓核心验证 3.加入busybox指令集 4.加入Root权限 5.时间居中显示.通知图标不会重叠 6.加入网速显示 7.加入%1精 ...
- Struts2流程
Struts2流程 1.client浏览器初始化时发出HTTP请求 2.依据web.xml配置,上述请求被FilterDispatcher接收 3.依据struts.xml配置,找到须要调用的Acti ...
- Cocos2d-x 3.2 大富翁游戏项目开发-第五部分 单机游戏-级别选择ScrollView
于MenuScene.cpp 点击单机游戏后会调用 Director::getInstance()->pushScene(MapChooseScene::createScene()); 进入到关 ...
- GDI+学问------ 绘制可变角度的色彩渐变效果
GDI+ 它是GDI(Windows 图形设备接口提供的早期版本)也许是版本号,它是Microsoft Windows XP作系统即兴许版本号的图形显示技术. 它已经集成到了.Net开发环境中.所以无 ...
- B二分法
<span style="color:#330099;">/* B - 二分法 基金会 Time Limit:1000MS Memory Limit:65536KB 6 ...
- ZOJ 2724 Windows 消息队列 (优先队列)
链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2724 Message queue is the basic fund ...
- ASP.NET 5:依赖注入
ASP.NET 5:依赖注入 1.背景 如果某个具体的(或类)对象被客户程序所依赖,通常把它们抽象成抽象类或接口.简单说,客户程序摆脱所依赖的具体类型,称之为面向接口编程. 那么问题来了?如何选择客户 ...