菜鸟教程简介:Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用,和丰富的 HTTP 工具。
使用 Express 可以快速地搭建一个完整功能的网站。
使用express创建一个基本的网站(用vs code开发)。(根据Node与Express开发那本书的例子)
1、首先npm init,初始化package.json文件;npm install --save express安装express;
2、接下来创建meadowlark.js文件,这是项目的入口。(最终代码)
var express = require('express'); var app = express(); var handlebars = require('express3-handlebars') .create({ defaultLayout:'main' }); app.engine('handlebars', handlebars.engine); app.set('view engine', 'handlebars'); app.use(express.static(__dirname + '/public')); app.get('/', function(req, res){ res.render('home'); }); app.get('/about', function(req, res){ var randomFortune = fortunes[Math.floor(Math.random() * fortunes.length)]; res.render('about', { fortune : randomFortune }); }); app.use(function(req, res, next){ res.status(404); res.render('404'); }); app.use(function(err, req, res, next){ console.error(err.stack); res.status(500); res.render(500); }); app.listen(3000, function () { console.log('访问地址为:'); }) var fortunes = [ "随机发送幸运饼干1", "随机发送幸运饼干2", "随机发送幸运饼干3", "随机发送幸运饼干4", ]
学到的技术点:
指定端口的方式:app.set(port, process.env.PORT || 3000);
app.get是我们添加路由的方法,有两个参数:一个路径和一个函数。在express文档中写的是app.VERB.VERB指代HTTP动词(get和post)。
app.use是添加中间件的方法。在express中路由和中间件的添加顺序很重要,如果把404处理器放在所有路由上面,那首页和关于页面就不能用了。
3、使用模板框架express3-handlebars,用npm下载,之后设置handlebars视图引擎。views/layout/main.handlebars为默认通用框架。
配置代码:
var handlebars = require('express3-handlebars') .create({ defaultLayout:'main' }); app.engine('handlebars', handlebars.engine); app.set('view engine', 'handlebars');
4、在第三步创建handlebars实例时,我们指明了默认布局{ defaultLayout:'main' },意味着所有视图用的都是这个布局。接下来给首页创建视图页面,meadowlark/views/home.handlebars:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Meadowlark Travel</title>
</head>
<body>
<header><img src="/img/favicon.ico" alt=""></header>
{{{body}}}
</body>
</html>
7、视图中的动态内容
在meadowlark.js中定义一个幸运饼干数组: