项目创建
来用命令创建一个nodejs项目
通过idea或者pycharm之类的创建项目的过程中有很多坑
- 安装node.js插件
- 创建nodes.js项目
- 设置项目配置(除了项目名称和路径外其他的按默认走)
- 正常情况下会报错
Error creating Node.js Express App. Cannot find C:\Users\MVGOS\AppData\Local\Temp\intellij-express-generator0.tmp\node_modules\express-generator
- 首先检查express安装了没有,以及相关的依赖(如npm)是否安装了
- 上网查资料,说express版本问题,有两种解决方法:上网查资料,说express版本问题,有两种解决方法:
a. 创建低版本的项目发现报了创建低版本的项目,发现报了新的错误
b. 通过命令行创建
express --view=jade first_nodejs
发现执行完句命令之后就卡了,换了条命令
express --view=ejs first_nodejs
命令执行结束了,并显示:
create : first_nodejs\
create : first_nodejs\public\
create : first_nodejs\public\javascripts\
create : first_nodejs\public\images\
create : first_nodejs\public\stylesheets\
create : first_nodejs\public\stylesheets\style.css
create : first_nodejs\routes\
create : first_nodejs\routes\index.js
create : first_nodejs\routes\users.js
create : first_nodejs\views\
create : first_nodejs\views\error.ejs
create : first_nodejs\views\index.ejs
create : first_nodejs\app.js
create : first_nodejs\package.json
create : first_nodejs\bin\
create : first_nodejs\bin\www
change directory:
> cd first_nodejs
install dependencies:
> npm install
run the app:
> SET DEBUG=first-nodejs:* & npm start
通过idea打开,发现还是不行,网上说上面的显示结果中的
change directory:
> cd first_nodejs
install dependencies:
> npm install
run the app:
> SET DEBUG=first-nodejs:* & npm start
这几行是需要你手动执行的,所以:进入第7步
7. 执行上面三条命令
8. 重新用ide打开项目
9. 安装ejs插件,没提示安装的话在项目中找一个ejs后缀的文件打开会提示安装ejs插件的,然后安装就可以了
–
项目介绍
(此处复制了别人的博客 nodeJS入门——新建一个项目及代码详解)
❤下面详细解释一下,项目中各个目录的功能用途,
app.js:——启动文件,也可以说是主文件入口。
package.json——定义了这个项目所需要的各种模块,以及项目的配置信息(比如名称、版本、许可证等元数据)。npm install命令根据这个配置文件,自动下载所需的模块,也就是配置项目所需的运行和开发环境。
node_modules——存放package.json中安装的模块,当你在package.json添加依赖的模块并安装后,存放在这个文件夹下
public——存放image、css、js等文件
routes——存放路由文件
views——存放视图文件或者说模板文件
bin——存放可执行文件
❤app.js里的代码及其解释
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var index = require('./routes/index');
var users = require('./routes/users');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', index);
app.use('/users', users);
// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
module.exports = app;
-
这里我们通过require()加载了express、path 等模块,以及 routes 文件夹下的index. js和 users.js 路由文件。 下面来讲解每行代码的含义。
-
var app = express(); 生成一个express实例。app.
-
app.set(‘views’, path.join(__dirname, ‘views’));设置views文件夹为存放视图文件的目录,即存放模板文件的目录。_dirname为全局变量,存储当前正在执行的脚本所在的目录。
-
app.set(‘view engine’, ‘ejs’); 设置视图模板引擎为ejs。
-
app.use(logger('dev’)):加载日志中间件。
-
app.use(bodyParser.json()):加载解析json的中间件。
-
app.use(bodyParser.urlencoded({ extended: false }));
加载解析urlencoded请求体的中间件。 -
app.use(cookieParser()):加载解析cookie的中间件。
-
app.use(express.static(path.join(__dirname, ‘public’))):设置public文件夹为存放静态文件的目录。
-
app.use(’/’, index);和app.use(’/users’, users):路由控制器。
-
app.use(function(req, res, next) {
var err = new Error(‘Not Found’);
err.status = 404;
next(err);
});
捕获404错误,并转发到错误处理器。
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
开发环境下的错误处理器,将错误信息渲染error模版并显示到浏览器中。
- module.exports = app;:导出app实例供其他模块调用。
❤bin/www代码及其详解
#!/usr/bin/env node
/**
* Module dependencies.
*/
var app = require('../app');
var debug = require('debug')('nodeproject1:server');
var http = require('http');
/**
* Get port from environment and store in Express.
*/
var port = normalizePort(process.env.PORT || '3000');
app.set('port', port);
/**
* Create HTTP server.
*/
var server = http.createServer(app);
/**
* Listen on provided port, on all network interfaces.
*/
server.listen(port);
server.on('error', onError);
server.on('listening', onListening);
/**
* Normalize a port into a number, string, or false.
*/
function normalizePort(val) {
var port = parseInt(val, 10);
if (isNaN(port)) {
// named pipe
return val;
}
if (port >= 0) {
// port number
return port;
}
return false;
}
/**
* Event listener for HTTP server "error" event.
*/
function onError(error) {
if (error.syscall !== 'listen') {
throw error;
}
var bind = typeof port === 'string'
? 'Pipe ' + port
: 'Port ' + port;
// handle specific listen errors with friendly messages
switch (error.code) {
case 'EACCES':
console.error(bind + ' requires elevated privileges');
process.exit(1);
break;
case 'EADDRINUSE':
console.error(bind + ' is already in use');
process.exit(1);
break;
default:
throw error;
}
}
/**
* Event listener for HTTP server "listening" event.
*/
function onListening() {
var addr = server.address();
var bind = typeof addr === 'string'
? 'pipe ' + addr
: 'port ' + addr.port;
debug('Listening on ' + bind);
}
-
#!/usr/bin/env node:表明是 node 可执行文件。
-
var debug = require(‘debug’)(‘nodeproject1:server’);:引入debug模块,打印调试日志。
-
var app = require(’…/app’):引入我们上面导出的app实例。
-
var port = normalizePort(process.env.PORT || ‘3000’);
app.set(‘port’, port); 设置端口号。 -
剩下的代码用来启动工程并监听3000端口。
❤routes/index.js
var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/', function(req, res, next) {
res.render('index', { title: 'Express' });
});
module.exports = router;
生成一个路由实例用来捕获访问主页的GET请求,导出这个路由并在app.js中通过app.use(’/’, routes); 加载。这样,当访问主页时,就会调用res.render(‘index’, { title: ‘Express’ });渲染views/index.ejs模版并显示到浏览器中。
❤views/index.ejs
<!DOCTYPE html>
<html>
<head>
<title><%= title %></title>
<link rel='stylesheet' href='/stylesheets/style.css' />
</head>
<body>
<h1><%= title %></h1>
<p>Welcome to <%= title %></p>
</body>
</html>
在渲染模板时我们传入了一个变量 title 值为 express 字符串,模板引擎会将所有 <%= title %> 替换为 express ,然后将渲染后生成的html显示到浏览器中。