当前位置: 首页>前端>正文

express教程ejs html express入门

html" class="superseo">Express 是一个基于 Node.js 平台的极简、灵活的 web 应用开发框架,帮助开发者快速的搭建 web 应用。本实验带您快速入门 Express,踏入基于 Node.js 平台的 web 开发的世界。

安装 NodeJS

  • 安装 NodeJS
    在终端中,使用下面的命令安装 NodeJS:
curl --silent --location https://rpm.nodesource.com/setup_8.x | sudo bash -
yum -y install nodejs
  • 安装完成后,可使用下面的命令测试安装结果:
node -v

安装 Express

  • 创建工作目录
    使用下面的命令在服务器创建一个工作目录:
mkdir -p /data/release/hello

进入此工作目录:

cd /data/release/hello
  • 初始化项目
    通过npm init 命令为你的应用创建一个 package.json 文件。欲了解package.json是如何起作用的,请参考 Specifics of npm’s package.json handling。
npm init

此命令将要求你输入几个参数,例如此应用的名称和版本。 除 entry point: (index.js) 参数外,其他参数你可以直接按“回车” 键接受默认设置即可。

对于entry point: (index.js)参数,键入 app.js 或者你所希望的名称,这是当前应用的入口文件;如果你希望采用默认的index.js文件名,只需按“回车”键即可。

express教程ejs html express入门,express教程ejs html express入门_html,第1张

安装 Express

接下来安装 Express 并将其保存到依赖列表中:

npm install express --save

如果只是临时安装 Express,不想将它添加到依赖列表中,只需略去--save参数即可 :

npm install express

Hello world

  • 创建 app.js
    在 hello 目录中,创建 app.js,然后将下列代码复制进去:
var express = require('express');
var app = express();

app.get('/', function (req, res) {
  res.send('Hello World!');
});

var server = app.listen(3000, function () {
  console.log('Example app listening on port 3000!');
});

完成后,使用Ctrl + S保存文件。

上面的代码启动一个服务并监听从 3000 端口进入的所有连接请求。他将对所有 (/) URL 或 路由 返回 “Hello World!” 字符串。对于其他所有路径全部返回 404 Not Found 。

req (请求) 和 res (响应) 与 Node 提供的对象完全一致,因此,你可以调用 req.pipe()、req.on('data', callback) 以及任何 Node 提供的方法。

  • 启动应用
    通过如下命令启动此应用:
node app.js

然后在浏览器中打开 http://119.29.130.84:3000 并查看输出结果。
(如果访问不成功,可能是机器安全组禁用了 3000 端口所致,你可以前往控制台修改安全组配置。)
该步骤完成后,可使用 Ctrl + C 终止运行。

Express 应用生成器

  • 安装 Express 应用生成器
    通过应用生成器工具 express 可以快速创建一个应用的骨架。
    通过如下命令安装:
npm install express-generator -g

-h 选项可以列出所有可用的命令行选项:

express -h

将得到输出:

Usage: express [options] [dir]

  Options:

    -h, --help          output usage information
    -V, --version       output the version number
    -e, --ejs           add ejs engine support (defaults to jade)
        --hbs           add handlebars engine support
    -H, --hogan         add hogan.js engine support
    -c, --css <engine>  add stylesheet <engine> support (less|stylus|compass|sass) (defaults to plain css)
        --git           add .gitignore
    -f, --force         force on non-empty directory
  • 创建项目
    进入工作目录:
cd /data/release

执行如下命令,在当前工作目录下创建一个命名为 myapp 的应用:

express myapp

完成后,点击查看 myapp 项目。
生成的应用程序具有以下目录结构:

├── app.js
├── bin
│   └── www
├── package.json
├── public
│   ├── images
│   ├── javascripts
│   └── stylesheets
│       └── style.css
├── routes
│   ├── index.js
│   └── users.js
└── views
    ├── error.pug
    ├── index.pug
    └── layout.pug

7 directories, 9 files
  • 启动应用
    进入该应用目录:
cd myapp

然后安装所有依赖包:

npm install

启动这个应用(MacOS 或 Linux 平台):

DEBUG=myapp npm start

然后在浏览器中打开 http://139.199.21.16:3000 网址就可以看到这个应用了。
(该步骤完成后,可使用 Ctrl + C 终止运行。)

基本路由

  • Express 路由简介
    路由(Routing)是由一个 URI(或者叫路径)和一个特定的 HTTP 方法(GET、POST 等)组成的,涉及到应用如何响应客户端对某个网站节点的访问。
    每一个路由都可以有一个或者多个处理器函数,当匹配到路由时,这些函数将被执行。
    路由的定义由如下结构组成:
app.METHOD(PATH, HANDLER)

其中:

  • app是一个 express 实例;
  • METHOD 是某个 HTTP 请求方式 中的一个
  • PATH 是服务器端的路径;
    +HANDLER 是当路由匹配到时需要执行的函数。
  • 一个简单的 Express 路由
  • 修改 hello 项目
    返回开始创建的 hello 项目:
cd /data/release/hello

编辑 app.js,参考修改如下:

var express = require('express');
var app = express();

// 对网站首页的访问返回 "Hello World!" 字样
app.get('/', function (req, res) {
  res.send('Hello World!');
});

// 网站首页接受 POST 请求
app.post('/', function (req, res) {
  res.send('Got a POST request');
});

// /user 节点接受 PUT 请求
app.put('/user', function (req, res) {
  res.send('Got a PUT request at /user');
});

// /user 节点接受 DELETE 请求
app.delete('/user', function (req, res) {
  res.send('Got a DELETE request at /user');
});

var server = app.listen(3000, function () {
  console.log('Example app listening on port 3000!');
});
  • 启动应用
node app.js

(该步骤完成后,可使用 Ctrl + C 终止运行。)

  • 测试
    你可以使用 curl 命令或 Postman 等工具进行测试。
    如在本地终端执行:
curl -X POST http://139.199.21.16:3000
curl -X PUT http://139.199.21.16:3000/user
curl -X DELETE http://139.199.21.16:3000/user\

静态文件

  • 利用 Express 托管静态文件
    通过 Express 内置的 express.static 可以方便地托管静态文件,例如图片、CSS、JavaScript 文件等。
  • 创建静态目录
    创建 public 目录:
    mkdir -p /data/release/hello/public
    在 public 目录下,创建 hello.html,然后复制下列代码到 hello.html 中:
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
</head>
<body>
  <h1>Hello World</h1>
</body>
</html>
  • 修改应用
    编辑 app.js,参考修改如下:
var express = require('express');
var app = express();

app.use(express.static('public'));

var server = app.listen(3000, function () {
  console.log('Example app listening on port 3000!');
});

我们在 app.js 中将静态资源文件所在的目录作为参数传递给 express.static 中间件,这样就可以提供静态资源文件的访问了。

  • 启动应用
node app.js

在浏览器中打开 http://139.199.21.16:3000/hello.html 网址就可以看到这个文件了。

你还可以将本地的文件通过拖拽至左边目录树的 public 目录上传文件来测试。
假设在 public 目录放置了图片、CSS 和 JavaScript 文件,你就可以从浏览器中访问:

http://139.199.21.16:3000/images/kitten.jpg
http://139.199.21.16:3000/css/style.css
http://139.199.21.16:3000/js/app.js
http://139.199.21.16:3000/images/bg.png
http://139.199.21.16:3000/hello.html
  • static 中间件更多用法
  • 多个目录
    如果你的静态资源存放在多个目录下面,你可以多次调用express.static中间件:
app.use(express.static('public'));
app.use(express.static('files'));

访问静态资源文件时,express.static 中间件会根据目录添加的顺序查找所需的文件。

  • 指定路径
    如果你希望所有通过 express.static 访问的文件都存放在一个“虚拟(virtual)”目录(即目录根本不存在)下面,可以通过为静态资源目录指定一个挂载路径的方式来实现,如下所示:
    编辑 app.js,参考修改如下:
var express = require('express');
var app = express();

app.use('/static', express.static('public'));

var server = app.listen(3000, function () {
  console.log('Example app listening on port 3000!');
});

启动应用:

node app.js

现在,你就可以通过带有 “/static” 前缀的地址来访问 public 目录下面的文件了。如:
http://139.199.21.16:3000/static/hello.html

想法、意识远比技术本身更有传授的价值! 多积累,肯动脑子,肯动手敲代码,多学习,提升自己的能力和对编程思想的理解能力才是最关键!




https://www.xamrdz.com/web/22x1960157.html

相关文章: