将ejs转为html,Node.js Express Web应用框架ejs修改为html

npm安装命令:npm install ejs -save

工程结构说明:

1541523153933030896.jpg

bin:存放可执行文件。

node_modules:存放package.json中安装的模块,在package.json添加依赖的模块并安装后,存放在这个文件夹下。

public:存放image、css、js等文件。

routes:存放路由文件。

views:存放视图文件或者说模版文件。

app.js:启动文件,或者说入口文件。

package.json:存储着工程的信息及模块依赖,当在dependencies中添加依赖的模块时,运行npm install ,npm会检查当前目录下的package.json,并自动安装所有指定的模块。

启动文件app.js// 通过require()加载模块

var createError = require('http-errors');

var express = require('express');

var path = require('path');

var cookieParser = require('cookie-parser');

var logger = require('morgan');

var indexRouter = require('./routes/index');

var usersRouter = require('./routes/users');

// 生成express实例

var app = express();

// 设置views文件夹为存放视图文件的目录

app.set('views', path.join(__dirname, 'views'));

// 设置视图模板引擎为ejs

app.set('view engine', 'ejs');

// 加载日志中间件

app.use(logger('dev'));

// 加载解析json的中间件。

app.use(express.json());

// 加载解析urlencoded请求体的中间件

app.use(express.urlencoded({ extended: false }));

// 加载解析cookie的中间件

app.use(cookieParser());

// 设置public文件夹为存放静态文件的目录

app.use(express.static(path.join(__dirname, 'public')));

// 路由控制器

app.use('/', indexRouter);

app.use('/users', usersRouter);

// 捕获404错误,并转发到错误处理器

app.use(function(req, res, next) {

next(createError(404));

});

// 错误处理

app.use(function(err, req, res, next) {

res.locals.message = err.message;

res.locals.error = req.app.get('env') === 'development' ? err : {};

res.status(err.status || 500);

res.render('error');

});

module.exports = app;

bin/www文件:#!/usr/bin/env node

/**

* 模块依赖关系

*/

var app = require('../app');

var debug = require('debug')('helloworld:server');

var http = require('http');

/**

* 从Express存储环境中获取端口号

*/

var port = normalizePort(process.env.PORT || '3000');

app.set('port', port);

/**

* 创建HTTP服务

*/

var server = http.createServer(app);

/**

* 监听所有的网络接口

*/

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);

}

修改ejs扩展名为HTML

app.js文件修改var ejs = require('ejs');

......

app.engine('html',ejs.__express);

app.set('view engine', 'html');

1541524131591098189.jpg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值