Node.js 入门

news2025/1/27 13:20:50

目录

定义

什么是前端工程化?

Node.js 为何能执行 JS?

Node.js 安装

使用 Node.js

fs 模块 - 读写文件

path 模块 - 路径处理

案例 - 压缩前端 html

URL 中的端口号

常见的服务程序

http 模块-创建 Web 服务

浏览时钟(案例)

Node.js 模块化

什么是模块化?

CommonJS 标准

ECMAScript 标准 - 默认导出和导入

ECMAScript 标准 - 命名导出和导入

包的概念

npm - 软件包管理器

npm - 安装所有依赖

npm - 全局软件包 nodemon

Node.js 总结

Node.js 包:


定义

 作用:

使用 Node.js 编写服务器端程序

          编写数据接口,提供网页资源浏览功能等等  

          前端工程化:为后续学习 Vue 和 React 等框架做铺垫

什么是前端工程化?

前端工程化:开发项目直到上线,过程中集成的所有工具和技术

Node.js 是前端工程化的基础(因为 Node.js 可以主动读取前端代码内容)

Node.js 为何能执行 JS?

首先:浏览器能执行 JS 代码,依靠的是内核中的 V8 引擎(C++ 程序)

其次:Node.js 是基于 Chrome V8 引擎进行封装(运行环境)

区别:都支持 ECMAScript 标准语法,Node.js 有独立的 API

注意:Node.js 环境没有 DOM 和 BOM 等

Node.js 安装

要求:下载 node-v16.19.0.msi 安装程序(指定版本:兼容 vue-admin-template 模板)

安装过程:默认下一步即可

注释事项:

        安装在非中文路径下

        无需勾选自动安装其他配套软件

成功验证:

        打开 cmd 终端,输入 node -v  命令查看版本号

        如果有显示,则代表安装成功

使用 Node.js

需求:新建 JS 文件,并编写代码后,在 node 环境下执行

命令:在 VSCode 集成终端中,输入 node xxx.js,回车即可执行

1. Node.js 是什么?
Ø 基于 Chrome V8 引擎 封装, 是独立执行 JavaScript 代码的环境
2. Node.js 与浏览器环境的 JS 最大区别?
Ø Node.js 环境中 没有 BOM DOM
3. Node.js 有什么用?
Ø 编写后端程序:提供数据和网页资源等
Ø 前端工程化 :集成各种开发中使用的工具和技术
4. Node.js 如何执行代码?
Ø VSCode 终端中输入: node xxx.js 回车即可执行(注意路径)

fs 模块 - 读写文件

模块:类似插件,封装了方法/属性

fs 模块:封装了与本机文件系统进行交互的,方法/属性

语法:

1. 加载 fs 模块对象
2. 写入 文件内容
3. 读取 文件内容
const fs = require('fs')

fs.writeFile('./test.txt', 'hello', (err) => {
  if (err) {
    console.log(err)

  }
  else {
    console.log('写入ok')

  }
})

fs.readFile('./test.txt', (err, data) => {
  if (err) console.log(err)
  else {
    console.log(data)
    console.log(data.toString())// 把buffer数据流转成字符串

  }


})

path 模块 - 路径处理

问题:Node.js 代码中,相对路径是根据终端所在路径来查找的,可能无法找到你想要的文件

建议:在 Node.js 代码中,写绝对路径

补充:__dirname 内置变量(获取当前模块目录-绝对路径)

自己理解:__dirname是当前js文件所在的文件夹,并且是绝对路径

windows D:\ 备课代码 \3-B 站课程 \03_Node.js Webpack \03-code\03
mac :       /Users/xxx/Desktop/ 备课代码 /3-B 站课程 /03_Node.js Webpack /03-code/03

注意:path.join() 会使用特定于平台的分隔符,作为定界符,将所有给定的路径片段连接在一起

语法:

1. 加载 path 模块
2. 使用 path.join 方法,拼接路径

const fs = require('fs')

const path = require('path')
console.log(__dirname)

fs.readFile(path.join(__dirname, '../test.txt'), (err, data) => {
  if (err) console.log(err)
  else {
    console.log(data.toString())// 把buffer数据流转成字符串
  }
})




案例 - 压缩前端 html

需求:把 回车符(\r)和换行符(\n)去掉后,写入到新 html 文件中

步骤:

1. 读取 html 文件内容
2. 正则 替换 字符串
3. 写入 到新的 html 文件中
const fs = require('fs')
const path = require('path')
fs.readFile(path.join(__dirname, 'public/index.html'), (err, data) => {
  if (err) console.log(err)
  else {

    const htmlStr = data.toString()
    const resultStr = htmlStr.replace(/[\r\n]/g)
    console.log(resultStr)


    fs.writeFile(path.join(__dirname, 'dist/index.html'), resultStr, err => {
      if (err) console.log(err)
      else {
        console.log('okok')
      }
    })

  }

})

URL 中的端口号

URL统一资源定位符,简称网址用于访问服务器里的资源

端口号:标记服务器里不同功能的服务程序

端口号范围:0-65535 之间的任意整数

注意:http 协议,默认访问 80 端口

常见的服务程序

Web 服务程序:用于提供网上信息浏览功能

注意:0-1023 和一些特定端口号被占用,我们自己编写服务程序请避开使用

http 模块-创建 Web 服务

需求:创建 Web 服务并响应内容给浏览器

步骤:

1. 加载 http 模块 ,创建 Web 服务对象
2. 监听 request 请求事件,设置响应头和响应体
3. 配置 端口号 启动 Web 服务
4. 浏览器请求 http:// localhost :3000 测试

localhost:固定代表本机的域名)

 

// 1.1 加载 http 模块,创建 Web 服务对象
const http = require('http')
const server = http.createServer()
// 1.2 监听 request 请求事件,设置响应头和响应体
server.on('request', (req, res) => {
  // 设置响应头-内容类型-普通文本以及中文编码格式
  res.setHeader('Content-Type', 'text/plain;charset=utf-8')
  // 设置响应体内容,结束本次请求与响应
  res.end('欢迎使用 Node.js 和 http 模块创建的 Web 服务')
})
// 1.3 配置端口号并启动 Web 服务
server.listen(3000, () => {
  console.log('Web 服务启动成功了')
})

浏览时钟(案例)

需求:基于 Web 服务,开发提供网页资源的功能

步骤:

1. 基于 http 模块,创建 Web 服务
2. 使用 req.url 获取请求 资源路径 ,判断并 读取 index.html 里字符串内容返回给请求方
3. 其他路径,暂时返回不存在的提示
4. 运行 Web 服务,用浏览器发起请求测试
const http = require('http')
const fs = require('fs')
const path = require('path')

const server = http.createServer()
server.on('request', (req, res) => {

  if (req.url === '/index.html') {
    fs.readFile(path.join(__dirname, 'dist/index.html'), (err, data) => {

      if (err) {
        console.log(err)

      } else {
        res.setHeader('Contenr-Type', 'text/html;charset=utf-8')
        res.end(data.toString())

      }

    })
  } else {
    res.setHeader('Contenr-Type', 'text/html;charset=utf-8')
    res.end('err tyy')


  }

})

server.listen(8080, () => {
  console.log('ok')
})

Node.js 模块化

什么是模块化

概念:项目是由很多个模块文件组成的

好处:提高代码复用性,按需加载,独立作用域

使用:需要标准语法导出导入进行使用

CommonJS 标准

需求:定义 utils.js 模块,封装基地址和求数组总和的函数

使用:

1. 导出: module.exports = {}
2. 导入: require(' 模块名或路径 ')

模块名或路径:

        内置模块:直接写名字(例如:fs,pathhttp

自定义模块:写模块文件路径(例如: ./utils.js

1. Node.js 中什么是模块化?
Ø 每个 文件 都是独立的模块
2. 模块之间如何联系呢?
Ø 使用特定语法, 导出 导入 使用
3. CommonJS 标准规定如何导出和导入模块呢?
Ø 导出: module.exports = {}
Ø 导入: require(' 模块名或路径 ')
4. 模块名 / 路径如何选择?
Ø 内置模块,直接写 名字 。例如: fs path http
Ø 自定义模块,写模块文件 路径 。例如: ./utils.js

ECMAScript 标准 - 默认导出和导入

需求:封装并导出基地址和求数组元素和的函数

默认标准使用:

1. 导出: export default {}
2. 导入: import 变量名 from ' 模块名或路径 '

注意:Node.js 默认支持 CommonJS 标准语法

如需使用 ECMAScript 标准语法,在运行模块所在文件夹新建 package.json 文件,

并设置 { "type" : "module" }

ECMAScript 标准 - 命名导出和导入

需求:封装并导出基地址和求数组元素和的函数

命名标准使用:

1. 导出: export 修饰定义语句
2. 导入: import { 同名变量 } from ' 模块名或路径‘

如何选择:

按需加载,使用命名导出和导入

全部加载,使用默认导出和导入

1. Node.js 支持哪 2 种模块化标准?
Ø CommonJS 标准语法(默认)
Ø ECMAScript 标准语法
2. ECMAScript 标准, 命名 导出和导入的语法?
Ø 导出: export 修饰定义的语句
Ø 导入: import { 同名变量 } from ' 模块名或路径‘
3. ECMAScript 标准, 默认 导出和导入的语法?
Ø 导出: export default {}
Ø 导入: import 变量名 from ' 模块名或路径 '

包的概念

包:将模块,代码,其他资料聚合成一个文件夹

包分类:

项目包:主要用于 编写项目 和业务逻辑
软件包: 封装工具和方法 进行使用

要求:根目录中,必须有 package.json 文件(记录包的清单信息)

注意:导入软件包时,引入的默认是 index.js 模块文件 / main 属性指定的模块文件

需求:封装数组求和函数的模块,判断用户名和密码长度函数的模块,形成成软件包

1. 什么是包?
 将模块,代码,其他资料聚合成的 文件夹
  一个文件可以当做一个模块
2. 包分为哪 2 类呢?
Ø 项目包:编写项目代码的文件夹
Ø 软件包 :封装工具和方法供开发者使用
3. package.json 文件的作用?
Ø 记录 软件包的名字 ,作者, 入口 文件等信息
4. 导入一个包文件夹的时候,导入的是哪个文件?
Ø 默认 index.js 文件 ,或者 main 属性 指定的文件

npm - 软件包管理器

使用:

1. 初始化清单文件  npm init -y (得到 package.json 文件,有这个文件则略过此命令)
2. 下载软件包  npm i 软件包名称
3. 使用软件包

需求:使用 dayjs 软件包,来格式化日期时间

图解:

1. npm 软件包管理器作用?
Ø 下载 软件 以及管理版本
2. 初始化项目清单文件 package.json 命令?
Ø npm init -y
3. 下载软件包的命令?
Ø npm i 软件包名字
4. 下载的包会存放在哪里?
Ø 当前项目下的 node_modules 中,并记录在 package.json

npm - 安装所有依赖

问题:项目中不包含 node_modules,能否正常运行?

答案:不能,缺少依赖的本地软件包

原因:因为,自己用 npm 下载依赖比磁盘传递拷贝要快得多

解决:项目终端输入命令:npm i

下载 package.json 中记录的所有软件包

1. 当项目中只有 package.json 没有 node_modules 怎么办?
Ø 当前项目下,执行 npm i 安装所有依赖软件包
2. 为什么 node_modules 不进行传递?
Ø 因为用 npm 下载比磁盘传递要快

npm - 全局软件包 nodemon

软件包区别:

Ø 本地软件包: 当前项目 内使用,封装 属性和方法 ,存在于 node_modules
Ø 全局软件包: 本机 所有项目使用,封装 命令和工具 ,存在于系统设置的位置

nodemon 作用:替代 node 命令,检测代码更改,自动重启程序

使用:

1. 安装: npm i nodemon -g -g 代表安装到全局环境中)
2. 运行: nodemon    待执行的目标 js 文件

需求:启动准备好的项目,修改代码保存后,观察自动重启应用程序

Node.js 总结

Node.js 模块化:

概念:每个文件当做一个模块,独立作用域,按需加载

模块化:项目是由很多个模块文件组成的

使用:采用特定的标准语法导出和导入进行使用

CommonJS  标准:一般应用在 Node.js 项目环境中

ECMAScript 标准:一般应用在前端工程化项目中

Node.js 包:

概念:把模块文件,代码文件,其他资料聚合成一个文件夹

项目包:编写项目需求和业务逻辑的文件夹

软件包:封装工具和方法进行使用的文件夹(一般使用 npm 管理)

ü 本地软件包:作用在 当前 项目,一般封装的 属性 / 方法 ,供项目调用编写业务需求
ü 全局软件包:作用在 所有 项目,一般封装的 命令 / 工具 ,支撑项目运行

常用命令:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1893987.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024最新中级会计职称考试全科题库资料。

1.根据消费税法律制度的规定,下列各项中,属于消费税征税范围的是()。 A.汽车轮胎 B.食用酒精 C.铂金首饰 D.体育上用的发令纸 答案:C 解析:选项ABD均不属于消费税的征税范围。 2.甲企业(…

2024亚太杯中文赛B题全保姆教程

B题 洪水灾害的数据分析与预测 问题 1. 请分析附件 train.csv 中的数据,分析并可视化上述 20 个指标中,哪 些指标与洪水的发生有着密切的关联?哪些指标与洪水发生的相关性不大?并 分析可能的原因,然后针对洪水的提前预…

基于Arduino平台开源小车的初步使用体验

创作原因:偶然有机会接触到基于Arduino平台的开源智能小车,初步使用后与大家分享。因使用时间不常,可以纯当个乐子看看,感谢大家的阅读! 图:一款基于Arduino平台的开源小车 一、开发环境 Misly&#xff1…

两个Activity之间切换时UI部分重叠

书籍 《第一行代码 Android》第三版 开发 环境 Android Studio Jellyfish | 2023.3.1 setContentView android studio自动生成的SecondActivity.kt中自动生成的代码中已经绑定了second_layout.xml的布局资源,通过代码:setContentView(R.layout.secon…

tkinter给按钮设置背景图片

tkinter给按钮设置背景图片 效果代码 效果 代码 import tkinter as tk from PIL import Image, ImageTk# 创建主窗口 root tk.Tk() root.title("按钮背景图片示例")# 加载图片 image Image.open("new.png") photo ImageTk.PhotoImage(image)# 创建按钮…

比Proxmox VE更易用的免费虚拟化平台

之前虚拟化一直玩Proxmox VE,最近发现一个更易用的虚拟化软件CSYun,他与Proxmox VE类似,都是一个服务器虚拟化平台。它不像VMware ESXi那么复杂,对于个人使用者和中小企业是一个比较好的选择。 这个软件所在的网址为:…

Nuxt3 的生命周期和钩子函数(十)

title: Nuxt3 的生命周期和钩子函数(十) date: 2024/6/30 updated: 2024/6/30 author: cmdragon excerpt: 摘要:本文详细介绍了Nuxt3框架中的五个webpack钩子函数:webpack:configResolved用于在webpack配置解析后读取和修改配置…

PCL从理解到应用【02】PCL环境安装 | PCL测试| Linux系统

前言 本文介绍在Ubuntu18.04系统中,如何安装PCL。 源码安装方式:pcl版本1.91,vtk版本8.2.0,Ubuntu版本18.04。 安装好后,可以看到pcl的库,在/usr/lib/中; 通过编写C代码,直接调用…

2.8亿东亚五国建筑数据分享

数据是GIS的血液! 我们现在为你分享东亚5国的2.8亿条建筑轮廓数据,该数据包括中国、日本、朝鲜、韩国和蒙古5个东亚国家完整、高质量的建筑物轮廓数据,你可以在文末查看领取方法。 数据介绍 虽然开源的全球的建筑数据已经有微软的建筑数据…

​埃文科技受邀出席2024 “数据要素×”生态大会​

2024“数据要素”生态大会(以下简称“大会”)于2024年6月30日在河南省郑州市举办。大会在国家数据局、河南省人民政府等单位的指导下,由中国经济体制改革研究会、中国电子信息产业集团有限公司、郑州市人民政府等共同主办。大会主题为“加快数…

C++字体库开发之字体回退三

代码片段 class FontCoverage { public: using SP std::shared_ptr<FontCoverage>; virtual ~FontCoverage() default; virtual void set(int index, FontTypes::CoverageLevel level) 0; virtual FontTypes::Coverag…

架构 | 数据归档

INDEX 1 通用思路2 快速归档3 归档整体流程&#xff08;完整归档 & 快速归档&#xff09;4 准备阶段4.1 确认归档表4.2 思路&#xff1a;确认归档数据范围 & 归档方案待选&#xff08;重点&#xff09;4.3 归档方式选择 & 业务场景覆盖4.4 确认归档数据范围 & …

Spring源码十:BeanPostProcess

上一篇Spring源码九&#xff1a;BeanFactoryPostProcessor&#xff0c;我们看到ApplicationContext容器通过refresh方法中的postProcessBeanFactory方法和BeanFactoryPostProcessor类提供预留扩展点&#xff0c;他可以在Spring容器的层面对BeanFactroy或其他属性进行修改&#…

微信小程序遮罩层显示

效果展示&#xff1a; wxml页面&#xff1a; <view classmodal-mask wx:if{{showModal}}><view class"modal-container"><view classmodal-content></view><view classmodal-footer bindtap"closeImage">//这个/images/ind…

MATLAB——循环语句

一、for end语句 在该语法中&#xff0c;循环变量是用于迭代的变量名&#xff0c;它会在每次循环迭代中从向量或矩阵中取出一列的值。数值向量或者矩阵则表示了循环变量可以取值的范围&#xff0c;通常根据实际需要事先给定。一旦循环变量遍历完数值向量或者矩阵中的所有值&…

【server】3、注册中心与配置中心

1、服务注册与发现 1.1、consul 1.1.1 是什么 官网&#xff1a; Consul by HashiCorp spring-cloud-consul: Spring Cloud Consul :: Spring Cloud Consul gitHub 官网 &#xff1a;GitHub - hashicorp/consul: Consul is a distributed, highly available, and data cent…

如何检查购买的Facebook账号优劣?

Facebook 是全球最受欢迎的社交网络之一,为品牌广告提供了巨大的潜力。许多公司和营销人员使用 Facebook 来推广他们的产品和服务&#xff0c;经常会购买账号。当然也分出了很多账号&#xff0c;比如个人号&#xff0c;BM号&#xff0c;广告号&#xff0c;小黑号等等。 但是,有…

一键安装部署,在 Ubuntu 服务器上快速搭建基于 Ghost CMS的网站

我们在上一篇内容中讲过&#xff0c;如何使用 Helm 在 Kubernetes 集群上安装 WordPress&#xff0c;创建高可用性网站。而这次我们将基于另一个流行的内容管理系统 Ghost CMS 在 DigitalOcean 云主机进行建站。 Ghost 也是开源的内容管理系统&#xff08;CMS&#xff09;&…

【Arduino】ESP8266开发环境配置(图文)

ESP8266与ESP32开发很类似&#xff0c;相当于是低配版本的ESP32&#xff0c;其同样具有无线网络连接能力&#xff0c;功能强大&#xff0c;而且价格比ESP32更具有优势。接下来我们就来设置一下ESP8266的开发环境。 使用Arduino开发平台软件&#xff0c;选择首选项进行设置。 h…

论文解析——Transformer 模型压缩算法研究及硬件加速器实现

作者及发刊详情 邓晗珂&#xff0c;华南理工大学 摘要 正文 实验平台 选取模型&#xff1a; T r a n s f o r m e r b a s e Transformer_{base} Transformerbase​ 训练数据集&#xff1a;WMT-2014 英语-德语翻译数据集、IWSLT-2014 英语-德语互译数据集 Transformer模…