什么是node.js、npm、vue

article/2025/8/28 0:59:37

一、Node.js 是什么?

😺 定义:

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时环境,让你可以在浏览器之外运行 JavaScript 代码,主要用于服务端开发。

😺从计算机底层说:什么是“运行环境”?
“运行环境” = 能接收你写的高级语言代码,并把它翻译成 CPU 能执行的机器指令,然后 管理运行所需的一切资源(内存、I/O、线程等) 的一套系统。

😺😺Node.js 是如何做到“运行 JS 代码”的?
1. node.exe 本质上 = V8 引擎 + Node API 的封装
2. 当你运行命令:

😺V8 引擎是怎么工作的?
• V8 本身也是用 C++ 写的
• 它把 JS 源码:
• 先解析成 AST(抽象语法树)
• 再编译成字节码(Bytecode)
• 然后使用 JIT(即时编译器)编译成机器码
• 最后直接交给 CPU 执行

😺什么是 Node API?

Node 提供了很多“可以直接调用的功能”,比如:
• fs.readFileSync() → 读文件
• http.createServer() → 启动服务器
• process.pid → 访问当前进程

😺看一下例子,那运行一个 .js 文件时到底发生了什么?

举例:你运行 node hello.js

背后的流程大致是这样:

1)你敲命令:node hello.js
• 系统运行 node.exe 程序
• 并把参数 hello.js 传进去

2)node 程序启动:初始化 C++ 层

Node 的主程序是 C++ 写的,它首先会做以下事:

main(argc, argv) {
InitNode(); // 初始化 Node 环境
InitV8(); // 初始化 V8 引擎
StartExecutionLoop(); // 开始 JS 代码执行流程
}

3)调用 V8,加载并解析 hello.js 文件
• Node 用 fs 模块(C++)读取 hello.js 源码(UTF-8 字符串)
• 把代码传给 V8:

v8::Script::Compile(js_code); // 编译 JS

4)V8 做的事(内部原理简化)

👉 V8 执行流程:
1. 把 JS 源码解析成 抽象语法树 AST
2. 编译成中间语言(字节码)
3. 热代码用 JIT 编译成本地机器码(x86 指令)
4. 执行!

5)JS 调用 Node API 时发生了啥?

假设你写了:

const fs = require(‘fs’);
fs.readFileSync(‘hello.txt’, ‘utf-8’);

•	require() 是 Node 实现的模块系统
•	fs.readFileSync 实际是 JS 调到 Node 的 C++ 层代码
•	通过 C++ 实现的 fs_module.cc 调用操作系统的文件 API(如 Windows 的 ReadFile,Linux 的 read())

6)事件循环(Event Loop)开始转起来了

如果你的代码中有异步操作,比如:

setTimeout(() => {
console.log(‘hello’);
}, 1000);

Node 会:
• 利用 libuv 库管理异步事件
• 注册回调、设置定时器
• 等待时钟完成后,事件循环调度你注册的 JS 回调重新进入 V8 执行

✅ 图示总结一下:

你敲:node hello.js

[ node.exe ] 启动(C++)

加载 V8 引擎(C++)

读取 JS 文件 → 源码字符串

[ V8 ]

  • 解析 JS
  • 编译成字节码
  • JIT 编译为机器码
  • 执行代码

    遇到 require(‘fs’) 等 Node API
    → 跳到 C++ 层的模块(文件系统、网络等)
    → 操作系统调用

    执行结果返回 JS

    继续事件循环(libuv)

😺npm是什么
npm(Node Package Manager)是 Node.js 的官方包管理工具,用来下载、安装、管理和分享 JavaScript 包(模块)。

用最简单的话来说:

npm 是一个 JS 世界的“应用市场 + 安装器 + 项目管理助手”。

它做了三件事:
1. 下载安装开源包:比如你运行 npm install express,它就从网上把 express 框架的代码包下载下来。
2. 自动管理依赖关系:比如 A 模块依赖 B 模块,npm 会自动把 B 一起装上,不需要你手动找。
3. 维护你的项目依赖信息:通过 package.json 这个文件记录你用的所有包版本,方便协作和还原环境。

🧠 它和 Node.js 是什么关系?
• Node.js 是运行环境(JS 解释器 + 系统 API)
• npm 是 Node.js 附带的“包管理器”

你安装 Node.js 的时候,其实 npm 也一并被装好了(就像你装了 Python,也会带上 pip)。

你可以在终端里输入:

node -v # 查看 Node 版本
npm -v # 查看 npm 版本

📦 npm 的核心组成:
1. npm CLI(命令行工具)
就是你常用的 npm install、npm run dev 等命令,其实是由 JS + Node 写的程序。
2. npm Registry(注册中心)
一个巨大的“线上代码仓库”,地址是 https://registry.npmjs.org
上面有几百万个 JS 包,是全世界开发者共享代码的中心。
3. package.json(项目描述文件)
记录你的依赖、项目名、脚本命令等,比如这样:

{
“name”: “my-app”,
“version”: “1.0.0”,
“dependencies”: {
“axios”: “^1.6.0”
},
“scripts”: {
“start”: “node index.js”
}
}

😺npm 管理的“包”到底是什么?

举个例子:
• 你写网页或服务器代码时,可能会用到别人写好的功能模块,比如:
• axios:帮你方便地发送网络请求(AJAX)
• express:快速搭建后端服务器框架
• lodash:提供各种实用的函数工具库
• moment 或 dayjs:处理时间和日期
• react 或 vue:前端的 UI 框架

这些“包”就是一堆写好的 JS 文件和资源集合,别人写好了,你直接装到项目里用,省时又省力。

😺Node.js 的应用场景:
• 构建 Web 服务(如 Express 框架)
• 命令行工具(如 npm)
• 文件处理 / 流式处理
• 后端 API 服务
• 前端工具链(webpack、vite、babel 都基于 Node)

😺js和node.js的对比
在这里插入图片描述

😺Vue 是做什么的?

Vue 是一个用于构建网页用户界面的 JavaScript 框架。

说人话就是:
你写网页的时候,不再用手搓 DOM、堆 jQuery,而是像搭积木一样写“组件”,Vue 帮你把它们拼起来、渲染成页面,并且自动响应数据变化。

🧱 它能帮你做什么?

✅ 1. 快速构建“动态网页”

Vue 的核心思想是:数据驱动视图。你只要绑定好数据,Vue 就帮你把页面更新到位。

{{ message }}

data() {
return { message: ‘你好,小*!’ }
}

只要你改了 message 的值,页面会立刻变,不用你去操作 DOM,特别适合开发复杂的网页应用。

✅ 2. 组件化开发

你可以把网页拆成一个个“小零件”(组件)来写,每个 .vue 文件就是一个功能独立的模块:
• 顶部导航栏组件
• 登录表单组件
• 商品列表组件
• 评论模块组件

这样不仅 易维护、可复用、便于协作开发,也更现代。

✅ 3. 丰富生态 + 插件

你刚才提到的这些:
• vue-router:做前端路由(页面切换)
• vuex 或 pinia:做全局状态管理
• axios:做网络请求
• element-plus:一整套好看的 UI 组件库

这些都可以和 Vue 搭配使用,帮你从页面到功能一步到位。

🚀 用 Vue 可以做哪些项目?
• 个人博客 / 作品集网站
• 电商后台管理系统(管理商品、订单、用户)
• 微信小程序 H5 前端
• 公司官网 / 展示页
• 与 Node.js 配合写全栈应用(前后端都用 JS)

😺比较js原生。vue。react的写法

•	✅ 原生 HTML + JS 怎么写
•	✅ 用 Vue 怎么写
•	✅ 用 React 怎么写

再告诉你Vue 和 React 的区别

🧪 需求:实现一个简单的“计数器”

功能:
• 显示一个数字(初始是 0)
• 点按钮,数字 +1

💻 1. 原生 HTML + JS 写法(手动操作 DOM)

0

点我加 1
<script>let count = 0;function increment() {count++;document.getElementById('counter').innerText = count;}
</script>

🧠 问题:
• 要手动获取 DOM、更新内容。
• 页面和数据是“分开的”,容易出 bug。
• 难以维护,逻辑混乱。

🍃 2. Vue 写法(数据驱动视图)

{{ count }}

✅ 好处:
• 页面和数据绑定在一起({{ count }} 自动显示)
• 不需要自己操作 DOM
• 写法直观,逻辑清晰

⚛️ 3. React 写法(函数组件 + Hook)

import React, { useState } from ‘react’;

function Counter() {
const [count, setCount] = useState(0);

return (


{count}


<button onClick={() => setCount(count + 1)}>点我加 1

);
}

export default Counter;

✅ 特点:
• 也是数据驱动视图(count 改变页面自动更新)
• 使用 useState() 管理状态
• 语法偏向函数式,写法更自由灵活

🆚 Vue 和 React 的对比(简要版)

特点 Vue React
核心理念 模板 + 数据驱动视图 全部是 JavaScript,函数式思维
视图写法 template 模板语法 JSX(JavaScript + HTML 混写)
响应式系统 内置响应式系统(自动追踪依赖) 通过 useState / useEffect 管理
学习曲线 更亲民(适合初学者) 更自由但更抽象(适合有经验者)
状态管理 Vuex / Pinia Redux / Zustand / Context API 等
社区支持 中国生态超强,文档中文好 全球最火,招聘岗位多

✅ 总结一句话对比:
• 原生 JS 是手动木工:你写的代码像“自己锯木头、拼木板”
• Vue 是半自动装配:你提供模板 + 数据,Vue 帮你装好
• React 是全 JS 式装配:你用函数式思维、写纯 JS,灵活但对脑子有点挑战


http://www.hkcw.cn/article/RmZIjLQIFS.shtml

相关文章

华为OD机试真题——求最多可以派出多少支队伍(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现

2025 A卷 100分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分…

webrtc初了解

1. webrtc的简介 一、WebRTC 是什么&#xff1f; Web Real-Time Communication&#xff08;网页实时通信&#xff09;&#xff0c;是浏览器原生支持的实时音视频通信技术&#xff0c;无需安装插件或客户端&#xff0c;可直接在浏览器之间实现点对点&#xff08;P2P&#xff09…

【Deepseek 学网络互联】跨节点通信global 和节点内通信CLAN保序

Clan模式下的源端保序与Global类似&#xff0c;目的端保序则退化成通道保序&#xff0c;此时仅支持网络单路径保序。”这里的通道保序怎么理解&#xff1f; 用户可能正在阅读某种硬件架构文档&#xff08;比如NVIDIA的NVLink或InfiniBand规范&#xff09;&#xff0c;因为"…

​Windows 11 安装 Miniconda 与 Jupyter 全流程指南​

​一、Miniconda 安装与配置​ 1. 下载安装程序 ​访问官网​&#xff1a;打开 Miniconda 官网&#xff0c;下载 ​Python 3.x 版本的 Windows 64 位安装包​。​安装路径选择​&#xff1a; 推荐路径&#xff1a;D:\Miniconda3&#xff08;避免使用中文路径和空格&#xff0…

飞牛NAS+Docker技术搭建个人博客站:公网远程部署实战指南

文章目录 前言1. Docker下载源设置2. Docker下载WordPress3. Docker部署Mysql数据库4. WordPress 参数设置5. 飞牛云安装Cpolar工具6. 固定Cpolar公网地址7. 修改WordPress配置文件8. 公网域名访问WordPress总结 前言 在数字化浪潮中&#xff0c;传统网站搭建方式正面临前所未…

批目标灵活模拟!成都鼎讯雷达模拟器,打造沉浸式雷达对抗训练场景

在现代战争的电磁频谱博弈中&#xff0c;能否构建高度逼真的雷达干扰与目标环境&#xff0c;直接决定着雷达装备性能的上限与作战人员的实战能力。成都鼎讯凭借在数字射频存储&#xff08;DRFM&#xff09;、数字干扰调制&#xff08;DJS&#xff09;等前沿技术的深厚积累&…

GelSight Mini触觉传感器:7μm精度+3D 映射,赋能具身智能精密操作

GelSight Mini 高分辨率视触觉传感器采用先进的光学成像与触觉感知技术&#xff0c;赋予机器人接近人类的触觉能力。该设备可捕捉物体表面微观细节&#xff0c;并生成高精度的2D/3D数字映射&#xff0c;帮助机器人识别形状、纹理及接触力&#xff0c;从而执行更复杂、精准的操作…

【机器学习基础】机器学习入门核心算法:随机森林(Random Forest)

机器学习入门核心算法&#xff1a;随机森林&#xff08;Random Forest&#xff09; 1. 算法逻辑2. 算法原理与数学推导2.1 核心组件2.2 数学推导2.3 OOB&#xff08;Out-of-Bag&#xff09;误差 3. 模型评估评估指标特征重要性可视化 4. 应用案例4.1 医疗诊断4.2 金融风控4.3 遥…

Nacos 配置管理案例:nacos-spring-cloud-config-example详解

一、结构说明&#xff1a;基于Spring Cloud Alibaba的微服务示例 nacos-spring-cloud-config-example : 服务提供者 二、技术栈&#xff1a;Spring BootSpring CloudSpring Cloud Alibaba Nacos Actuator&#xff08;可选&#xff1a;监控&#xff09; 三、使用环境 安装…

Python训练营---Day39

知识点回顾 图像数据的格式&#xff1a;灰度和彩色数据模型的定义显存占用的4种地方 模型参数梯度参数优化器参数数据批量所占显存神经元输出中间状态 batchisize和训练的关系 作业&#xff1a;今日代码较少&#xff0c;理解内容即可 1、图像数据的格式&#xff1a;灰度和彩色数…

KeePass安装与KeePass设置中文教程

一、下载KeePass 访问官网&#xff1a;https://keepass.info 1&#xff0c;点击最新版本 2&#xff0c;下载最新版本 3&#xff0c;选择你要下载的版本 二、安装KeePass 1&#xff0c;第一步 2&#xff0c;第二步&#xff08;一直点Next&#xff09; 3&#xff0c;安装…

SQL正则表达式总结

这里写目录标题 一、元字符二、正则表达函数1、 regexp_like(x,pattern[,match_option])2、 regexp_instr(x,pattern[,start[,occurrence[,return_option[, match_option]]]]) 3、 REGEXP_SUBSTR(x,pattern[,start[,occurrence[, match_option]]]) 4、 REGEXP_REPLACE(x,patter…

2025 一带一路暨金砖国家技能发展与技术创新大赛 第一届“信创适配及安全管理赛项”样题

2025 一带一路暨金砖国家技能发展与技术创新大赛 第一届“信创适配及安全管理赛项”样题 模块A-理论知识&#xff1a;模块B-适配环境搭建&#xff1a;系统安装与配置&#xff1a;DNS 服务配置&#xff1a;DNS 服务配置&#xff1a;CA 服务配置&#xff1a;Httpd 服务配置&#…

unity编辑器扩展dll形式展示

1.背景&#xff1a;最近搞工程迁移发现一旦c#报错就会导致编辑器菜单没法使用&#xff0c;做了一些尝试发现使用dll的方式会是不错的选择。当然有些工具还是建议用外部的c#工程来写比如winform. 2.遇到的问题&#xff1a;我记得之前2017年左右的时候做一个unity的dll工程并不需…

Nacos | 三种方式的配置中心,整合Springboot3.x + yaml文件完成 0错误 自动刷新(亲测无误)

目录 ValueRefreshScope 导入配置依赖 启动类 添加 EnableDiscoveryClient 控制器 编写 yaml 文件 创建 Nacos Data Id 项目启动问题 测试 ConfigurationProperties 无感自动刷新 导入配置依赖 启动类 添加 EnableDiscoveryClient 控制器 Nacos DataID 模板映射 编…

[嵌入式实验]实验五:freeRTOS

一、实验目的 熟悉开发环境在开发板上通过freeRTOS进行LED控制 二、实验环境 硬件&#xff1a;STM32开发板、CMSIS-DAP调试工具 软件&#xff1a;STM32CubeMX软件、ARM的IDE&#xff1a;Keil C51 三、实验内容 1.实验原理 freeRTOS是一种专门设计的嵌入式实时操作系统&…

【Unity】 HTFramework框架(六十六)缺省的运行时组件检视器

更新日期&#xff1a;2025年5月29日。 Github 仓库&#xff1a;https://github.com/SaiTingHu/HTFramework Gitee 仓库&#xff1a;https://gitee.com/SaiTingHu/HTFramework 索引 一、缺省的运行时组件检视器1.自定义运行时组件检视器 二、使用缺省的运行时组件检视器1.定义组…

Ollama v0.8.0 发布,支持通过工具调用进行流式响应!

在 2025 年 5 月 29 日的 AI 技术浪潮中&#xff0c;实时交互性和高效性成为 AI 应用的核心需求。Ollama 作为一个开源的大型语言模型服务器&#xff0c;持续更新以满足开发者需求。Ollama v0.8.0 的发布特别引入了支持通过工具调用进行流式响应的功能&#xff0c;这一更新引发…

LVS+Keepalived 高可用群集

目录 一、 Keepalived 双机热备核心技术 1.1 Keepalived 架构与 VRRP协议 1.2 双机热备配置深度优化 二、 LVSKeepalived 高可用负载均衡架构 2.1 系统架构设计 2.2 LVS集成配置详解 三、 关键技术与疑难解析 3.1 DR模式 ARP 仰制机制 3.2 健康检查策略优化 四、 企业…

python + vscode 开发环境搭建

一、下载安装Python Python 官网链接Welcome to Python.org 二、Python3.12.7安装 三、Python虚拟环境 开发编译器使用Vscode 1、打开VsCode&#xff0c;键盘输入ctrl shift p 点击完了会在文件夹目录下出现一个.venv的路径。 虚拟环境的作用是隔离不同项目的 Python 环境…