首页 web前端 js教程 什么是 Node.js

什么是 Node.js

Aug 01, 2024 am 01:44 AM

What is Nodejs

Nodejs 是一个 JavaScript 运行时。这意味着nodejs是一个允许您在浏览器之外运行JavaScript的程序。这样一来,就可以使用nodejs来开发后端应用程序了。现在,这不仅限于后端。我们可以构建桌面应用程序、物联网和云应用程序等等。 Nodejs 是跨平台的。该程序本身可以运行 Linux、Windows 和 macOS。

为什么要使用 Nodejs

Nodejs 具有一些优势,包括但不限于:

  • 非阻塞 I/O
  • 异步
  • 可扩展
  • 事件驱动
  • 低延迟
  • 有线程
  • 随时随地都可以使用
  • 拥有一个庞大的社区

俗话说,眼前的回报意味着长期的不便。这里的缺点是 javascript(顺便说一句,我喜欢 javascript),有时在设计您想要构建的系统时没有考虑到扩展性。再说一遍,不是 Nodejs,而是使用 Nodejs 的工具和人类。

您可以在这里阅读有关 Nodejs 的更多信息

安装

Nodejs 的人很聪明,尊重这一点。它们使您和我的安装变得更加容易。没有技术知识的人可以设置 Nodejs 并开始编写一些代码。他们提供了可以使用的选项:

  • 包管理器
  • 预构建的安装程序
  • 预构建的二进制文件
  • 通过构建源代码进行安装

其中,前三个是友好的。所以选择其中任何一个。让我们前往 download-nodejs 并“放一个 Nodejs”。

截至目前,当前节点版本为 22,LTS(具有长期支持)为 20。

我使用的是 Linux 机器,所以我将使用 nvm(Node 版本管理器)进行安装。这让我们感觉我们可以拥有多个版本的 Nodejs。这对于 macOS 来说也是开箱即用的。

# installs nvm (Node Version Manager)
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash

# download and install Node.js (you may need to restart the terminal)
nvm install 20

# verifies the right Node.js version is in the environment
node -v # should print `v20.15.1`

# verifies the right npm version is in the environment
npm -v # should print `10.7.0`

这与nodejs平台(网站)上的脚本相同。所以运行这些命令时应该不会有任何问题。

对于 Windows,类似的东西将是

# installs fnm (Fast Node Manager)
winget install Schniz.fnm

# download and install Node.js
fnm use --install-if-missing 20

# verifies the right Node.js version is in the environment
node -v # should print `v20.15.1`

# verifies the right npm version is in the environment
npm -v # should print `10.7.0`

或者只需下载预构建的安装程序,node-prebuilt-installer。最终,您应该能够运行最后两个命令来验证您的安装。

# verifies the right Node.js version is in the environment
node -v # should print `v20.15.1`

# verifies the right npm version is in the environment
npm -v # should print `10.7.0`

非易失性存储器

在安装过程中,nvm 不是 Windows 的选项,但可以在此处安装,了解一点它会很有教育意义。

我们使用命令 nvm list 列出我们拥有的所有其他版本的 Nodejs

username@computer-name:~$ nvm list
->     v18.18.0
default -> 18.18.0 (-> v18.18.0)
iojs -> N/A (default)
unstable -> N/A (default)
node -> stable (-> v18.18.0) (default)
stable -> 18.18 (-> v18.18.0) (default)
lts/* -> lts/hydrogen (-> v18.18.0)
lts/argon -> v4.9.1 (-> N/A)
lts/boron -> v6.17.1 (-> N/A)
lts/carbon -> v8.17.0 (-> N/A)
lts/dubnium -> v10.24.1 (-> N/A)
lts/erbium -> v12.22.12 (-> N/A)
lts/fermium -> v14.21.3 (-> N/A)
lts/gallium -> v16.20.2 (-> N/A)
lts/hydrogen -> v18.18.0

从上面我们可以看出v18.18.0是我运行的nodejs。

我们可以使用 nvm install 20 安装其他版本,例如 20 LTS

username@computer-name:~$ nvm install 20
Downloading and installing node v20.15.1...
Downloading https://nodejs.org/dist/v20.15.1/node-v20.15.1-linux-x64.tar.xz...
######################################################################### 100.0%
Computing checksum with sha256sum
Checksums matched!
Now using node v20.15.1 (npm v10.7.0)

这会自动切换到 v20.15.1。这是最新的 LTS。

现在我可以通过 nvm use 18 切换到我们想要的节点版本

username@computer-name:~$ nvm use 18
Now using node v18.18.0 (npm v10.8.2)
username@computer-name:~$
username@computer-name:~$ node -v
v18.18.0

这就是 nvm 上的

国家公共管理

npm 是一个节点包管理器。如果您想知道什么是包裹,请不要紧张。包与库相同。由其他人编写的一些代码片段或程序可以在我们的程序中用来执行某些操作。因此,包的目的是解决问题等等。 npm 和其他节点包管理器(如yarn、pnpm、bun 等)帮助我们管理为项目安装的包。我们在这里将只关注 npm。

要启动一个nodejs项目(不仅仅是javascript),我们需要使用node包。我的意思是,有时我们开发整个程序时不依赖第三方库(我们没有编写也不是 Nodejs 附带的程序)。

我们可以通过使用命令 npm init 创建节点 packege.json 文件来创建 Nodejs 应用程序。执行 npm init --help 来阅读有关 npm init 的更多信息。通常最好在新的环境(文件夹)中启动节点程序。所以我们将创建一个并将其命名为 helloworld。我将使用终端。

username@computer-name:~$ mkdir helloworld
username@computer-name:~$ cd helloworld/
username@computer-name:~/helloworld$ npm init
This utility will walk you through creating a package.json file.
It only covers the most common items and tries to guess sensible defaults.

See `npm help init` for definitive documentation on these fields
and exactly what they do.

Use `npm install <pkg>` afterwards to install a package and
save it as a dependency in the package.json file.

Press ^C at any time to quit.
package name: (helloworld) 
version: (1.0.0) 
description: 
entry point: (index.js) 
test command: 
git repository: 
keywords: 
author: 
license: (ISC) 
About to write to /home/username/helloworld/package.json:

{
  "name": "helloworld",
  "version": "1.0.0",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
 },
  "author": "",
  "license": "ISC",
  "description": ""
}

Is this OK? (yes) 

username@computer-name:~/helloworld$ 
  • 我创建了一个名为 mkdir helloworld 的文件夹
  • 我改进了helloworld文件夹,cd helloworld
  • 然后我初始化节点,npm init

它就像一个安装向导,引导您完成配置步骤。请注意,您可以稍后更新。您只需按“ENTER”、“ENTER”,直到整个过程结束。当您在文件资源管理器中打开 helloworld 文件夹时,您将看到一个新文件 package.json ,其内容与上面的输出类似。

{
  "name": "helloworld",
  "version": "1.0.0",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
 },
  "author": "",
  "license": "ISC",
  "description": ""
}

这个配置很直观。它告诉您我们将要创建的项目(或程序)的名称。它使用父文件夹名称作为项目名称。在节点(项目)初始化过程中,我们可以给它一个名称,甚至为其他字段提供值。这就是我们按下 ENTER、ENTER、...

的地方

Another way to run through this without hitting ENTER, ENTER, …, is to do, npm init -y . -y, mean, yes, use the default values.

Primarily, node packages are on npmjs.com. Let’s say we want to install the expressjs library. This is how to search for express on npmjs. The docs will tell you how to install it using the command, npm i express.

username@computer-name:~/helloworld$ npm i express

added 64 packages, and audited 65 packages in 4s

12 packages are looking for funding
  run `npm fund` for details

found 0 vulnerabilities

i means install. You write it out as npm install express. The package.json will be updated with the package added.

{
  "name": "helloworld",
  "version": "1.0.0",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
 },
  "author": "",
  "license": "ISC",
  "description": "",
  "dependencies": {
    "express": "^4.19.2"
 }
}

Now, we have a new dependency.

Note that no file or folder will be created. When we do ls

username@computer-name:~/helloworld$ ls
node_modules  package.json  package-lock.json
  • We have node_modules, which is a folder that holds the dependencies (packages) our program will use.
  • Also we have, package-lock.json, which serves as a lockfile, hence the name. It captures the exact versions of the package that we install and use to create our programs. This way, the same packages and their specific versions can be used all the time since different versions of the same package may behave differently.

Anyways, we can install packages in three ways or rather environment. This is basically where you want the package to be used.

  • global: This will be accessible to all node programs you have. Usually, install packages globally when they are general purpose programs like command line utilities.
  • development: This is meant for development only and not used on some remote servers since the remote server will have its way of handling the use case of that dependency. These are usually utility libraries that work with other libraries to achieve a purpose. These may include but are not limited to eslint, prettier, dotenv, etc.
  • production: This is a package that our application primarily relies on to function. Like express.

We can do,

  • npm i -g package-names ... to globally install a package
  • npm i --global package-names ... to globally install a package
  • npm i -S package-names ... to install a package (for production)
  • npm i --save package-names ... to install a package (for production)
  • npm i -D package-names ... to install a package (for development, you won’t need it to make our application run)
  • npm i --save-dev package-names ... to install a package (for development, you won’t need it to make our application run)
  • npm uninstall package-names ... to remove or uninstall package

Essentially this is all that we will need to manage our packages.

以上是什么是 Node.js的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

Rimworld Odyssey如何钓鱼
1 个月前 By Jack chen
Kimi K2:最强大的开源代理模型
1 个月前 By Jack chen
我可以有两个支付帐户吗?
1 个月前 By 下次还敢

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Laravel 教程
1602
29
PHP教程
1506
276
如何在node.js中提出HTTP请求? 如何在node.js中提出HTTP请求? Jul 13, 2025 am 02:18 AM

在Node.js中发起HTTP请求有三种常用方式:使用内置模块、axios和node-fetch。1.使用内置的http/https模块无需依赖,适合基础场景,但需手动处理数据拼接和错误监听,例如用https.get()获取数据或通过.write()发送POST请求;2.axios是基于Promise的第三方库,语法简洁且功能强大,支持async/await、自动JSON转换、拦截器等,推荐用于简化异步请求操作;3.node-fetch提供类似浏览器fetch的风格,基于Promise且语法简单

JavaScript数据类型:原始与参考 JavaScript数据类型:原始与参考 Jul 13, 2025 am 02:43 AM

JavaScript的数据类型分为原始类型和引用类型。原始类型包括string、number、boolean、null、undefined和symbol,其值不可变且赋值时复制副本,因此互不影响;引用类型如对象、数组和函数存储的是内存地址,指向同一对象的变量会相互影响。判断类型可用typeof和instanceof,但需注意typeofnull的历史问题。理解这两类差异有助于编写更稳定可靠的代码。

过滤JavaScript中的一系列对象 过滤JavaScript中的一系列对象 Jul 12, 2025 am 03:14 AM

JavaScript中filter()方法用于创建一个包含所有通过测试元素的新数组。1.filter()不修改原数组,而是返回符合条件元素的新数组;2.基本语法为array.filter((element)=>{returncondition;});3.可按属性值过滤对象数组,如筛选年龄大于30的用户;4.支持多条件筛选,例如同时满足年龄和名字长度条件;5.可处理动态条件,将筛选参数传入函数以实现灵活过滤;6.使用时注意必须返回布尔值,避免返回空数组,以及结合其他方法实现字符串匹配等复杂逻

如何检查数组是否在JavaScript中包含一个值 如何检查数组是否在JavaScript中包含一个值 Jul 13, 2025 am 02:16 AM

在JavaScript中检查数组是否包含某个值,最常用方法是includes(),它返回布尔值,语法为array.includes(valueToFind),例如fruits.includes('banana')返回true;若需兼容旧环境,则使用indexOf(),如numbers.indexOf(20)!==-1返回true;对于对象或复杂数据,应使用some()方法进行深度比较,如users.some(user=>user.id===1)返回true。

在异步/等待JavaScript函数中处理错误 在异步/等待JavaScript函数中处理错误 Jul 12, 2025 am 03:17 AM

处理异步函数中的错误应使用try/catch、在调用链中处理、使用.catch()方法、并监听unhandledrejection事件。1.使用try/catch捕获错误是推荐方式,结构清晰且能处理await中的异常;2.在调用链中处理错误可集中逻辑,适合多步骤流程;3.使用.catch()可在调用async函数后捕获错误,适用于Promise组合场景;4.监听unhandledrejection事件可记录未处理的rejection,作为最后一道防线;以上方法共同确保异步错误被正确捕获和处理。

JavaScript上下文中解释的虚拟DOM的概念 JavaScript上下文中解释的虚拟DOM的概念 Jul 12, 2025 am 03:09 AM

虚拟DOM是一种优化真实DOM更新的编程概念,通过在内存中创建与真实DOM对应的树形结构,避免频繁直接操作真实DOM。其核心原理是:1.数据变化时生成新的虚拟DOM;2.对比新旧虚拟DOM找出最小差异;3.批量更新真实DOM以减少重排重绘开销。此外,使用唯一稳定key可提升列表对比效率,而部分现代框架已采用其他技术替代虚拟DOM。

高级JavaScript范围和上下文 高级JavaScript范围和上下文 Jul 24, 2025 am 12:42 AM

JavaScript的作用域决定变量可访问范围,分为全局、函数和块级作用域;上下文决定this的指向,依赖函数调用方式。1.作用域包括全局作用域(任何地方可访问)、函数作用域(仅函数内有效)、块级作用域(let和const在{}内有效)。2.执行上下文包含变量对象、作用域链和this的值,this在普通函数指向全局或undefined,在方法调用指向调用对象,在构造函数指向新对象,也可用call/apply/bind显式指定。3.闭包是指函数访问并记住外部作用域变量,常用于封装和缓存,但可能引发

如何在JavaScript中添加活动侦听器? 如何在JavaScript中添加活动侦听器? Jul 12, 2025 am 03:11 AM

使用addEventListener添加事件监听器需注意:1.使用普通函数确保this指向元素;2.解绑时需用同一函数引用。JavaScript中通过element.addEventListener(eventType,handlerFunction,options)为元素绑定事件,支持多处理函数且不覆盖,如用btn.addEventListener('click',function(){});普通函数中的this指向元素本身,而箭头函数继承外层作用域,因此涉及this时应选用普通函数;若需移除

See all articles