Javascript 编程基础(2)基础知识 | 2.1、javascript与Node.js

文章目录

一、Node.js 与 JavaScript

1、基本概念

1.1、JavaScript:动态脚本语言

JavaScript 是一种高级的、解释型的编程语言,主要用于:

  • 为网页添加交互功能
  • 操作网页内容(DOM)
  • 处理用户事件
  • 与服务器通信(AJAX)
javascript 复制代码
// 典型的浏览器端JavaScript
document.getElementById('btn').addEventListener('click', () => {
  alert('按钮被点击!');
});

1.2、Node.js:JavaScript 运行时环境

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,主要特点:

  • 让 JavaScript 能在服务器端运行
  • 提供非阻塞 I/O 和事件驱动架构
  • 包含丰富的内置模块(文件系统、HTTP等)
javascript 复制代码
// 典型的Node.js代码
const http = require('http');
http.createServer((req, res) => {
  res.end('Hello Node.js!');
}).listen(3000);

2、核心区别

特性 JavaScript Node.js
运行环境 浏览器 服务器
主要用途 前端开发 后端开发
API访问 浏览器API(DOM,BOM等) 系统API(文件、网络等)
模块系统 ES6模块(import/export) CommonJS(require)
全局对象 window global
典型应用 网页交互 Web服务器、CLI工具

3、执行环境差异

3.1、浏览器中的JavaScript

  • 受限于浏览器沙箱安全模型
  • 无法直接访问系统资源
  • 依赖浏览器提供的API
  • 主要用于响应用户交互

3.2、Node.js中的JavaScript

  • 可以访问本地文件系统
  • 能创建网络服务
  • 可以执行系统命令
  • 适合I/O密集型应用
javascript 复制代码
// Node.js访问文件系统示例
const fs = require('fs');
fs.readFile('file.txt', 'utf8', (err, data) => {
  if (err) throw err;
  console.log(data);
});

4、共同点

尽管有上述区别,两者共享:

  • 相同的语言语法
  • 相同的数据类型
  • 相同的核心语言特性
  • 事件驱动编程模型

5、为什么需要Node.js?

  • 统一语言:前后端都使用JavaScript,降低学习成本
  • 高性能:非阻塞I/O适合高并发场景
  • 丰富的生态:npm拥有最大规模的包管理系统
  • 开发效率:代码复用和共享更方便

现代Web开发中,两者通常配合使用,JavaScript处理客户端逻辑,Node.js处理后端服务,共同构成完整的JavaScript全栈解决方案。

相关推荐
weixin_4723394613 分钟前
高效处理大体积Excel文件的Java技术方案解析
java·开发语言·excel
枯萎穿心攻击1 小时前
响应式编程入门教程第二节:构建 ObservableProperty<T> — 封装 ReactiveProperty 的高级用法
开发语言·unity·c#·游戏引擎
Eiceblue2 小时前
【免费.NET方案】CSV到PDF与DataTable的快速转换
开发语言·pdf·c#·.net
m0_555762903 小时前
Matlab 频谱分析 (Spectral Analysis)
开发语言·matlab
像风一样自由20203 小时前
HTML与JavaScript:构建动态交互式Web页面的基石
前端·javascript·html
浪裡遊4 小时前
React Hooks全面解析:从基础到高级的实用指南
开发语言·前端·javascript·react.js·node.js·ecmascript·php
whale fall4 小时前
npm install安装的node_modules是什么
前端·npm·node.js
会飞的鱼先生4 小时前
Node.js-http模块
网络协议·http·node.js
lzb_kkk4 小时前
【C++】C++四种类型转换操作符详解
开发语言·c++·windows·1024程序员节
好开心啊没烦恼5 小时前
Python 数据分析:numpy,说人话,说说数组维度。听故事学知识点怎么这么容易?
开发语言·人工智能·python·数据挖掘·数据分析·numpy