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

Node.js 完全教程:从入门到精通

Node.js 完全教程:从入门到精通

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,允许开发者在服务器端使用 JavaScript。它的非阻塞 I/O 和事件驱动架构使得 Node.js 非常适合于构建高性能的网络应用。本文将详细介绍 Node.js 的安装、基本语法、模块系统、异步编程、Express 框架、数据库操作等内容,帮助你从入门到精通 Node.js。
在这里插入图片描述

1. Node.js 简介

Node.js 是一个开源的、跨平台的 JavaScript 运行时环境,能够在服务器端执行 JavaScript 代码。它的特点包括:

  • 异步非阻塞:Node.js 使用事件驱动的非阻塞 I/O 模型,使得它能够处理大量并发请求。
  • 单线程:Node.js 运行在单线程上,但通过事件循环机制实现并发处理。
  • 高性能:得益于 V8 引擎,Node.js 执行 JavaScript 代码的速度非常快。

2. Node.js 安装

2.1 下载与安装

前往 Node.js 官方网站 下载适合你操作系统的安装包。安装过程非常简单,按照提示完成安装即可。

2.2 验证安装

打开终端(Windows 用户可以使用命令提示符),输入以下命令检查 Node.js 和 npm(Node.js 包管理器)的版本:

node -v
npm -v

如果安装成功,你将看到版本号输出。

在这里插入图片描述

3. Node.js 基本语法

3.1 Hello World 示例

创建一个新的 JavaScript 文件 app.js,并输入以下代码:

console.log("Hello, World!");

在终端中运行:

node app.js

输出结果:

Hello, World!
3.2 变量与数据类型

Node.js 支持 JavaScript 的所有基本数据类型,包括:

  • 字符串let name = "Node.js";
  • 数字let age = 25;
  • 布尔值let isNode = true;
  • 数组let fruits = ["apple", "banana", "orange"];
  • 对象let person = { name: "Alice", age: 30 };
3.3 控制结构

Node.js 支持常见的控制结构,如条件语句和循环。

3.3.1 条件语句
let age = 18;
if (age >= 18) {console.log("成年人");
} else {console.log("未成年人");
}
3.3.2 循环
for (let i = 0; i < 5; i++) {console.log(i);
}

4. 模块系统

Node.js 的模块化设计使得代码更易于维护和复用。使用 require 导入模块,使用 module.exports 导出模块。

4.1 创建模块

创建一个名为 math.js 的文件,内容如下:

function add(a, b) {return a + b;
}function subtract(a, b) {return a - b;
}module.exports = {add,subtract
};
4.2 使用模块

app.js 中使用刚刚创建的模块:

const math = require('./math');console.log(math.add(5, 3)); // 输出 8
console.log(math.subtract(5, 3)); // 输出 2

5. 异步编程

Node.js 的异步编程模型是其核心特性之一。通过回调函数、Promise 和 async/await 来处理异步操作。

5.1 回调函数
const fs = require('fs');fs.readFile('example.txt', 'utf8', (err, data) => {if (err) {console.error(err);return;}console.log(data);
});
5.2 Promise
const fs = require('fs').promises;fs.readFile('example.txt', 'utf8').then(data => {console.log(data);}).catch(err => {console.error(err);});
5.3 async/await
const fs = require('fs').promises;async function readFile() {try {const data = await fs.readFile('example.txt', 'utf8');console.log(data);} catch (err) {console.error(err);}
}readFile();

6. 创建 Web 服务器

Node.js 可以轻松创建 HTTP 服务器。以下是一个简单的服务器示例:

const http = require('http');const server = http.createServer((req, res) => {res.statusCode = 200;res.setHeader('Content-Type', 'text/plain');res.end('Hello, Node.js!
');
});server.listen(3000, () => {console.log('服务器运行在 http://localhost:3000/');
});

在终端中运行该文件后,打开浏览器访问 http://localhost:3000/,你将看到 “Hello, Node.js!” 的输出。

在这里插入图片描述

7. 使用 Express 框架

Express 是 Node.js 最流行的 Web 应用框架之一,简化了服务器的创建和路由管理。

7.1 安装 Express

使用 npm 安装 Express:

npm install express
7.2 创建一个简单的 Express 应用
const express = require('express');
const app = express();app.get('/', (req, res) => {res.send('Hello, Express!');
});app.listen(3000, () => {console.log('Express 服务器运行在 http://localhost:3000/');
});
7.3 路由管理
app.get('/about', (req, res) => {res.send('关于页面');
});app.get('/contact', (req, res) => {res.send('联系页面');
});

8. 数据库操作

Node.js 可以与多种数据库进行交互,包括 MongoDB、MySQL、PostgreSQL 等。以下是使用 MongoDB 的示例。

8.1 安装 MongoDB 驱动
npm install mongodb
8.2 连接 MongoDB
const { MongoClient } = require('mongodb');async function main() {const uri = "mongodb://localhost:27017";const client = new MongoClient(uri);try {await client.connect();console.log("成功连接到 MongoDB");} catch (err) {console.error(err);} finally {await client.close();}
}main().catch(console.error);
8.3 CRUD 操作
async function createDocument(client, newDocument) {const result = await client.db("test").collection("users").insertOne(newDocument);console.log(`新文档创建成功:${result.insertedId}`);
}

9. 错误处理

在 Node.js 中,错误处理是非常重要的。可以使用 try...catch 语句处理同步代码中的错误,对于异步代码,可以在 Promise 中使用 .catch() 方法。

async function riskyOperation() {try {// 可能抛出错误的操作} catch (error) {console.error("发生错误:", error);}
}

10. 中间件

在 Express 中,中间件是处理请求和响应的函数。可以用于日志记录、请求解析、身份验证等。

10.1 创建中间件
app.use((req, res, next) => {console.log(`${req.method} ${req.url}`);next(); // 调用下一个中间件
});
10.2 使用现成的中间件

可以使用 body-parser 中间件解析请求体:

npm install body-parserconst bodyParser = require('body-parser');app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));

11. 部署 Node.js 应用

将 Node.js 应用部署到云服务器(如 AWS、Heroku、DigitalOcean 等)是一个重要的步骤。以下是基本的部署步骤:

  1. 选择云服务提供商:选择适合的云服务提供商并创建账户。
  2. 配置服务器:根据提供商的文档配置服务器环境。
  3. 上传代码:使用 Git 或 FTP 将代码上传到服务器。
  4. 安装依赖:在服务器上运行 npm install 安装依赖。
  5. 启动应用:使用 node app.js 启动应用,或者使用 PM2 等进程管理工具保持应用运行。

在这里插入图片描述

12. 总结

本文详细介绍了 Node.js 的基础知识、模块系统、异步编程、Web 服务器创建、Express 框架、数据库操作等内容。通过示例代码和图示,帮助你更好地理解和掌握 Node.js 的使用。希望这份教程能对你学习 Node.js 有所帮助,祝你在开发中取得成功!

如果你有任何问题或建议,欢迎在评论区留言。感谢你的阅读!

相关文章:

Node.js 完全教程:从入门到精通

Node.js 完全教程&#xff1a;从入门到精通 Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境&#xff0c;允许开发者在服务器端使用 JavaScript。它的非阻塞 I/O 和事件驱动架构使得 Node.js 非常适合于构建高性能的网络应用。本文将详细介绍 Node.js 的安装、基本语…...

elasticsearch 数据导出/导入

例子&#xff1a; 导出命令&#xff1a; elasticdump --inputhttps://elastic:elasticsearchlocalhost:9100/company --outputcompany.json --typedata --no-verify 注意&#xff0c;本地docker搭建&#xff0c;禁用自签证书验证&#xff0c;先设置环境变量 export NODE_TL…...

什么是三高架构?

大家好&#xff0c;我是锋哥。今天分享关于【什么是三高架构?】面试题。希望对大家有帮助&#xff1b; 什么是三高架构? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 “三高架构”通常是指高可用性&#xff08;High Availability&#xff09;、高性能&#xff…...

Docker 单机快速部署大数据各组件

文章目录 一、Spark1.1 NetWork 网络1.2 安装 Java81.3 安装 Python 环境1.4 Spark 安装部署 二、Kafka三、StarRocks四、Redis五、Rabbitmq六、Emqx6.1 前言6.2 安装部署 七、Flink八、Nacos九、Nginx 一、Spark 1.1 NetWork 网络 docker network lsdocker network create -…...

CSS笔记基础篇01——选择器、文字控制属性、背景属性、显示模式、盒子模型

黑马程序员视频地址&#xff1a; 前端Web开发HTML5CSS3移动web视频教程https://www.bilibili.com/video/BV1kM4y127Li?vd_source0a2d366696f87e241adc64419bf12cab&spm_id_from333.788.videopod.episodeshttps://www.bilibili.com/video/BV1kM4y127Li?vd_source0a2d3666…...

pytest全局配置文件pytest.ini

pytest.ini 改变 pytest 的默认行为&#xff0c;一般放在项目的根目录&#xff0c;不能包含中文符号。不管是主函数模式运行&#xff0c;命令行模式运行&#xff0c;都会去读取这个全局配置文件。 [pytest] ;配置命令行参数&#xff0c;用空格进行分隔。addopts 中的选项会被命…...

PyTest自学-认识PyTest

1 PyTest自学-认识PyTest 1.1 PyTest可以用来做什么&#xff1f; PyTest是一个自动化测试框架&#xff0c;支持单元测试和功能测试&#xff0c;有丰富的插件&#xff0c;如&#xff0c;pytest-selemium, pytest-html等。 1.2 安装pytest 使用pip install -U pytest。 1.3 py…...

【专题】为2025制定可付诸实践的IT战略规划报告汇总PDF洞察(附原数据表)

原文链接&#xff1a;https://tecdat.cn/?p39055 在当今瞬息万变的商业环境中&#xff0c;制定有效的 IT 战略规划对于企业的成功与可持续发展至关重要。本报告深入探讨了制定 IT 战略规划的关键活动&#xff0c;旨在为企业和决策者提供全面且实用的指导。 Gartner的《为202…...

自旋锁与CAS

上文我们认识了许许多多的锁&#xff0c;此篇我们的CAS就是从上文的锁策略开展的新概念&#xff0c;我们来一探究竟吧 1. 什么是CAS&#xff1f; CAS: 全称Compare and swap&#xff0c;字⾯意思:“比较并交换”&#xff0c;⼀个CAS涉及到以下操作&#xff1a; 我们假设内存中…...

数组-二分查找

目录 算法思想&#xff1a; 实践&#xff1a; 备注&#xff1a; 二分查找是一种高效的查找算法&#xff0c;适用于在 有序数组 或列表中快速定位目标元素的索引。 重要事情说三遍&#xff1a;使用前提&#xff1a;数组有序&#xff0c;无重复&#xff0c;如果数组未排序&am…...

如何使用 Python 进行文件读写操作?

大家好&#xff0c;我是 V 哥。今天的内容来介绍 Python 中进行文件读写操作的方法&#xff0c;这在学习 Python 时是必不可少的技术点&#xff0c;希望可以帮助到正在学习 python的小伙伴。 以下是 Python 中进行文件读写操作的基本方法&#xff1a; 一、文件读取&#xff1…...

springcloud中的Feign调用

目录 一、基础应用 1.feign使用 1.增加feign依赖 2.编写feign接口 3.启用feign 4.调试 5.可能出现的异常信息 1.404 可能原因: 2.503 可有原因: 2.feign自定义配置 1.创建Feign配置类 2.feign接口 3.调试结果 3.feign多参数请求 Feign是Netflix开发的声明…...

【部署】将项目部署到云服务器

目录 1.获得服务器 2.连接到云服务器 3.配置环境 3.1.Java&#xff08;运行后端所需&#xff09; 3.2.MySQL数据库 3.3.Nginx&#xff08;运行前端所需&#xff09; 3.4. Node.js&#xff08;构建前端所需&#xff09; 4.打包项目 4.1.打包后端项目 4.2.打包前端项目…...

2024年AI大模型技术年度总结与应用实战:创新与突破并进

前言 回顾2024年&#xff0c;我一共发布了286篇博文&#xff0c;粉丝数也达到了43000多。这一年里&#xff0c;我收获颇丰&#xff0c;始终坚持AI大模型的研究方向&#xff0c;并且积极开展大模型的实战应用&#xff0c;也取得了一系列令人振奋的突破。 在286篇博文中&#…...

docker离线安装及部署各类中间件(x86系统架构)

前言&#xff1a;此文主要针对需要在x86内网服务器搭建系统的情况 一、docker离线安装 1、下载docker镜像 https://download.docker.com/linux/static/stable/x86_64/ 版本&#xff1a;docker-23.0.6.tgz 2、将docker-23.0.6.tgz 文件上传到服务器上面&#xff0c;这里放在…...

SuperdEye:一款基于纯Go实现的间接系统调用执行工具

关于SuperdEye SuperdEye是一款基于纯Go实现的间接系统调用执行工具&#xff0c;该工具是TartarusGate 的修订版&#xff0c;可以利用Go来实现TartarusGate 方法进行间接系统调用。 该工具的目标是为了扫描挂钩的NTDLL并检索Syscall编号&#xff0c;然后使用它来执行间接系统调…...

PCL 新增自定义点类型【2025最新版】

目录 一、自定义点类型1、前言2、定义方法3、代码示例二、合并现有类型三、点云按时间渲染1、CloudCompare渲染2、PCL渲染博客长期更新,本文最近更新时间为:2025年1月18日。 一、自定义点类型 1、前言 PCL库自身定义了很多点云类型,但是在使用的时候时如果要使用自己定义的…...

Docker导入镜像

使用命令行进行处理&#xff1a; docker load < onething1_wxedge.tar如下图所示 查看状态 docker images...

PyTorch使用教程(9)-使用profiler进行模型性能分析

1、简介 PyTorch Profiler是一个内置的性能分析工具&#xff0c;可以帮助开发者定位计算资源&#xff08;如CPU、GPU&#xff09;的瓶颈&#xff0c;从而更好地优化PyTorch程序。通过捕获和分析GPU的计算、内存和带宽利用情况&#xff0c;能够有效识别并解决性能瓶颈。 2、原…...

SpringBoot中使用MyBatis-Plus详细介绍

目录 一、MyBatis-Plus的使用步骤 1.引入MybatisPlus的起步依赖 2.定义Mapper&#xff08;也叫dao&#xff09;层的接口 3.MyBatis-Plus中常用注解 4. 使用MyBatis-Plus时要做如下配置 5.条件构造器 Wrapper 一、MyBatis-Plus的使用步骤 1.引入MybatisPlus的起步依赖 M…...

OpenClaw隐私保护:千问3.5-9B本地化处理敏感数据方案

OpenClaw隐私保护&#xff1a;千问3.5-9B本地化处理敏感数据方案 1. 为什么我们需要本地化AI处理 去年处理一份投资协议时&#xff0c;我犯了个致命错误——将包含客户隐私条款的合同上传到某云端AI工具进行摘要生成。三天后&#xff0c;法务团队在公开搜索引擎的缓存记录中发…...

Kandinsky-5.0-I2V-Lite-5s性能调优:加速推理与降低显存占用的技巧

Kandinsky-5.0-I2V-Lite-5s性能调优&#xff1a;加速推理与降低显存占用的技巧 1. 引言 如果你正在使用Kandinsky-5.0-I2V-Lite-5s进行图像到视频的生成任务&#xff0c;可能会遇到两个常见问题&#xff1a;推理速度不够快和显存占用过高。这篇文章将分享几个实用的性能调优技…...

AUTOSAR兼容性验证失败?车载C#中控系统代码合规性自查清单,含ISO 26262 ASIL-B级代码审计模板

第一章&#xff1a;AUTOSAR兼容性验证失败的根因诊断与应对策略AUTOSAR兼容性验证失败往往并非单一模块缺陷所致&#xff0c;而是由配置不一致、接口语义偏差、RTE生成逻辑冲突及基础软件&#xff08;BSW&#xff09;版本错配等多维度因素交织引发。快速定位根本原因需构建分层…...

Limine混合ISO制作教程:BIOS/UEFI双启动镜像的完整流程

Limine混合ISO制作教程&#xff1a;BIOS/UEFI双启动镜像的完整流程 【免费下载链接】limine Modern, advanced, portable, multiprotocol bootloader and boot manager. 项目地址: https://gitcode.com/gh_mirrors/li/limine Limine是一款现代化、先进的可移植多协议引导…...

Kuikly实现Android iOS Web小程序一码覆盖实践

跨端开发趋势与“一码覆盖”的现实路径 在多终端普及与用户场景碎片化的背景下&#xff0c;移动、桌面、Web与小程序的并行发展让“一次开发、多端运行”成为开发者的核心诉求。传统方案中&#xff0c;React Native因桥接机制存在通信延迟与UI不一致问题&#xff0c;Flutter因…...

打工人必备!8个AI办公神器,每天准时下班不是梦

文档处理工具Notion AI 集成在Notion中的AI功能&#xff0c;支持自动生成文档大纲、会议纪要整理、多语言翻译。通过自然语言输入需求&#xff0c;快速输出结构化内容&#xff0c;适合项目管理与知识库搭建。ChatPDF 上传PDF文件后可直接对话式提问&#xff0c;提取关键信息或总…...

【Python原生AOT编译2026企业落地白皮书】:覆盖金融/车载/边缘场景的7大不可替代性验证数据

第一章&#xff1a;Python原生AOT编译的2026企业级定位与战略价值从运行时依赖到零依赖交付 2026年&#xff0c;Python原生AOT&#xff08;Ahead-of-Time&#xff09;编译已突破实验阶段&#xff0c;成为金融、电信与边缘IoT等高合规、低延迟场景的核心交付范式。它不再依赖CPy…...

TwinCAT3实战指南:PLC变量与硬件IO的高效绑定技巧

1. TwinCAT3环境搭建与基础概念 第一次接触TwinCAT3的工程师常常会被各种专业术语搞得晕头转向。其实可以把TwinCAT3想象成一个"翻译官"&#xff0c;它负责把PLC程序中的变量指令"翻译"成硬件能听懂的电信号。我刚开始使用时&#xff0c;最头疼的就是变量定…...

Aseprite新手必看:5分钟搞定像素角色基础动画(附完整工程文件)

Aseprite像素动画速成指南&#xff1a;从静态角色到生动动作的5分钟魔法 第一次打开Aseprite时&#xff0c;我被它简洁的界面和强大的功能震撼了——作为一个独立游戏开发者&#xff0c;我需要快速制作角色动画&#xff0c;但又不想陷入复杂的美术流程。经过多次实践&#xff…...

从DINO Score到LLaVA:拆解SPAA论文如何用“双考官”机制筛选高质量AI修图

从DINO Score到LLaVA&#xff1a;构建AI图像编辑的"双考官"质量评估体系 在AI图像编辑技术快速发展的今天&#xff0c;如何系统评估生成结果的质量已成为产品落地的关键瓶颈。传统方法往往依赖人工审核或单一指标&#xff0c;既难以规模化又无法全面捕捉图像修改的语…...