项目知识——“Node.js 让 JavaScript 摆脱了只能运行在浏览器中的限制

HTTP 服务器是什么?

HTTP 服务器 就是一个持续运行的程序,它:

  1. 监听网络端口(通常是 80 或 443)

  2. 接收浏览器发来的 HTTP 请求(如访问网页、提交表单)

  3. 处理请求(读取文件、查询数据库等)

  4. 返回 HTTP 响应(HTML、JSON、图片等)

简单说,它就像餐厅里的服务员:随时待命,顾客(浏览器)点餐(发请求),服务员向后厨(服务器资源)下单,最后把菜(响应内容)端上桌。


JavaScript 的"困境":为什么原来只能在浏览器跑?

浏览器中的 JavaScript 就像被关在一个沙盒监狱里:

  • 能做的事 :操作网页内容(DOM)、发网络请求(Ajax)、用浏览器提供的 API(如 localStorage

  • 绝对不能做的事 :直接读写本地文件、监听网络端口、创建进程等系统级操作

因为浏览器为了安全,严格限制了它的权限。JavaScript 解释器(如 V8)是嵌在浏览器里的,离开浏览器这个宿主环境,代码就无法执行。


Node.js 的破局:把 JavaScript"搬到"服务器

Node.js 做了两件革命性的事:

  1. 把 V8 引擎从浏览器里"抠"出来

Node.js 直接把 Chrome 的 V8 引擎(JavaScript 解释器)独立打包 ,让它能在操作系统上直接运行,不再依赖浏览器。

  1. 给 JavaScript 装上"手脚"(系统 API)

Node.js 提供了一套C++ 编写的底层模块 (如 fshttpnet),把操作系统的文件、网络、进程等能力封装成 JavaScript 函数

javascript 复制代码
// 在服务器上监听 3000 端口(以前绝对做不到!)
const http = require('http');
const fs = require('fs');

http.createServer((req, res) => {
  // 直接读写服务器硬盘文件
  const content = fs.readFileSync('./index.html');
  res.end(content);
}).listen(3000);

本质区别

维度 浏览器 JavaScript Node.js JavaScript
宿主环境 浏览器 操作系统
权限 沙盒限制,只有 Web API 完整系统权限,可直接操作硬件资源
用途 操纵网页、用户交互 构建服务器、CLI 工具、桌面应用
全局对象 window global

Node.js 不是新语言,它只是给 JavaScript 换了个"操作系统级"的运行环境,让它从"网页脚本"变成了"通用编程语言",所以原来只能在浏览器跑的代码,现在能直接在服务器上监听端口、处理请求了。

相关推荐
代码or搬砖6 小时前
使用nvm管理node多版本
vue.js·node.js
Q_Q19632884756 小时前
python+django/flask+vue的智能房价分析与预测系统
spring boot·python·django·flask·node.js·php
Q_Q5110082856 小时前
python+django/flask+vue的购物管理系统
spring boot·python·django·flask·node.js
Q_Q5110082856 小时前
python+springboot+django/flask基于数据挖掘的高考志愿推荐系统
spring boot·python·django·flask·node.js·php
Q_Q5110082856 小时前
python+springboot+django/flask基于用户评论主题挖掘的旅游景点推荐系统
spring boot·python·django·flask·node.js
Q_Q19632884757 小时前
python+django/flask+vue的历届奥运会数据可视化分析系统
spring boot·python·django·flask·node.js
Q_Q19632884757 小时前
python+django/flask+vue基于机器学习的就业岗位推荐系统
spring boot·python·django·flask·node.js
Q_Q5110082857 小时前
python+django/flask+vue基于深度学习的图书推荐系统
spring boot·python·django·flask·node.js·php
LYFlied7 小时前
Webpack详细打包流程解析
前端·面试·webpack·node.js·打包·工程化