Home Web Front-end JS Tutorial Nodejs express usage tutorial (with code)

Nodejs express usage tutorial (with code)

May 16, 2016 pm 03:30 PM
express nodejs

Express is a simple and flexible node.js web application development framework. It provides a series of powerful features to help you create various web and mobile device applications.

1.express organizational structure

app demo

|---node_modules------for Install local modules.
|---public------------ is used to store files that users can download, such as pictures, scripts, style sheets, etc.
|---routes------------ is used to store routing files.
|---views------------- Used to store templates for web pages.
|---app.js------------The startup script of the application.
|---package.json------Project configuration file.

2.. Create express server

//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('Listening on port %d', server.address().port);
});
Copy after login

Run nodejs application

/>node app.js

3. Middleware

Middleware is a function that handles HTTP requests.
When an HTTP request enters the server, the server instance will call the first middleware. After completion, it will decide whether to call the next middleware according to the settings.

The parameters of the middleware are:

. When there are four - the first is error handling, the second is client request, the third is server response respond, and the fourth is next middleware. Such as function(error, request, response, next){}
. Three times---the first client requests request, the second is server response respond, and the third is next middleware. Such as function(request, response, next){ }
. When there are two---the first client requests request, and the second responds to the server respondfunction. Such as function(request, response){}

4. Use middleware use

use is express’s method of calling middleware, which returns a function.

app.use(function(request, response) {
 response.writeHead(200, { "Content-Type": "text/plain" });
 response.end("Hello world!\n");
});
Copy after login

5. Error content display

app.use(express.bodyParser());//使用body参数
app.use(express.methodOverride());//使用函数覆盖
app.use(app.router);//使用路由
app.use(function(err, req, res, next){
 console.error(err.stack);
 res.send(500, 'Something broke!');
});//错误内容显示
Copy after login

6. Routing

There are many ways to route express. Here are some commonly used examples:

.app.use('/', middleware);//When getting/posting, the processing of path /
.app.get("/", middleware);//When getting in http, the processing of path/
.app.post("/", middleware);//When post in http, the processing of path/ / Processing
.app.put("/", middleware);//When putting in http, processing of path/
.app.delete("/", middleware);//Delete in http When processing the path/

.: Capture path content

8. Set environment variables set
app.get("*", function(request, response) {
 response.end("404!");
});//所有路径都返回404
Copy after login

set is used to specify the value of a variable.

app.set("view engine", "ejs");//Use ejs as a template
app.get("/hello/:who", function(req, res) {
 res.end("Hello, " + req.params.who + ".");
});//如"/hello/alice”网址,网址中的alice将被捕获,作为req.params.who属性的值
Copy after login

9. response object method.Redirect redirect


response.redirect("/hello/anime");//Redirect to /hello/anime

.Send file sendFile response.sendFile("/path/to/anime.mp4");

. Render the web page template render, that is, load the transformed content into the web page.

response.render("index", { message: "Hello World" });//Pass the message variable into the index template, with the value "Hello World" rendered into an HTML web page

10. requst object method


. Get the customer ip address: request.ip

. Get the uploaded files: request.files

11. Startup script package.json

package.json is used to specify app information, nodejs version number and dependencies of other components

12.app entrance app.js

app.js mainly includes http creation, basic routing, and listening port number

{
  "name": "demo",
  "description": "My First Express App",
  "version": "0.0.1",
  "dependencies": {
   "express": "3.x"
  }
}
Copy after login
13. Dynamic web page template views

views folder is used to store all web page templates.

14. Specify the static web page directory

//app.js
app.use(express.static('public'));/ /Specify the static web page directory. When the browser sends a request for a non-HTML file, the server will go to the public directory to look for the file

For example:, the server will go to the public/bootstrap/css/ directory to look for bootstrap.css File

Okay, this tutorial will be introduced to you here. We will continue to update you in the future. Thank you for your continued support of the PHP Chinese website.

【Recommended related tutorials】

1. JavaScript video tutorial
2. JavaScript online manual
3. bootstrap tutorial

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

The difference between nodejs and tomcat The difference between nodejs and tomcat Apr 21, 2024 am 04:16 AM

The main differences between Node.js and Tomcat are: Runtime: Node.js is based on JavaScript runtime, while Tomcat is a Java Servlet container. I/O model: Node.js uses an asynchronous non-blocking model, while Tomcat is synchronous blocking. Concurrency handling: Node.js handles concurrency through an event loop, while Tomcat uses a thread pool. Application scenarios: Node.js is suitable for real-time, data-intensive and high-concurrency applications, and Tomcat is suitable for traditional Java web applications.

The difference between nodejs and vuejs The difference between nodejs and vuejs Apr 21, 2024 am 04:17 AM

Node.js is a server-side JavaScript runtime, while Vue.js is a client-side JavaScript framework for creating interactive user interfaces. Node.js is used for server-side development, such as back-end service API development and data processing, while Vue.js is used for client-side development, such as single-page applications and responsive user interfaces.

Is nodejs a backend framework? Is nodejs a backend framework? Apr 21, 2024 am 05:09 AM

Node.js can be used as a backend framework as it offers features such as high performance, scalability, cross-platform support, rich ecosystem, and ease of development.

What is the difference between npm and npm.cmd files in the nodejs installation directory? What is the difference between npm and npm.cmd files in the nodejs installation directory? Apr 21, 2024 am 05:18 AM

There are two npm-related files in the Node.js installation directory: npm and npm.cmd. The differences are as follows: different extensions: npm is an executable file, and npm.cmd is a command window shortcut. Windows users: npm.cmd can be used from the command prompt, npm can only be run from the command line. Compatibility: npm.cmd is specific to Windows systems, npm is available cross-platform. Usage recommendations: Windows users use npm.cmd, other operating systems use npm.

How to connect nodejs to mysql database How to connect nodejs to mysql database Apr 21, 2024 am 06:13 AM

To connect to a MySQL database, you need to follow these steps: Install the mysql2 driver. Use mysql2.createConnection() to create a connection object that contains the host address, port, username, password, and database name. Use connection.query() to perform queries. Finally use connection.end() to end the connection.

Is nodejs a back-end development language? Is nodejs a back-end development language? Apr 21, 2024 am 05:09 AM

Yes, Node.js is a backend development language. It is used for back-end development, including handling server-side business logic, managing database connections, and providing APIs.

What are the global variables in nodejs What are the global variables in nodejs Apr 21, 2024 am 04:54 AM

The following global variables exist in Node.js: Global object: global Core module: process, console, require Runtime environment variables: __dirname, __filename, __line, __column Constants: undefined, null, NaN, Infinity, -Infinity

Is there a big difference between nodejs and java? Is there a big difference between nodejs and java? Apr 21, 2024 am 06:12 AM

The main differences between Node.js and Java are design and features: Event-driven vs. thread-driven: Node.js is event-driven and Java is thread-driven. Single-threaded vs. multi-threaded: Node.js uses a single-threaded event loop, and Java uses a multi-threaded architecture. Runtime environment: Node.js runs on the V8 JavaScript engine, while Java runs on the JVM. Syntax: Node.js uses JavaScript syntax, while Java uses Java syntax. Purpose: Node.js is suitable for I/O-intensive tasks, while Java is suitable for large enterprise applications.

See all articles