NodeJS学习笔记
NodeJS软件安装
node环境安装:
https://nodejs.org
安装好后的node通常在C:\Program Files\nodejs验证安装是否成功
node -v
npm -v
进入REPL模式命令行模式
node
NodeJS在REPL模式和编辑器使用
windos在dos下常用命令
windos命令:
1、cmd
dos系统2、cls
清空屏幕3、exit
退出dos4、mkdir
创建命令5、dir
查看文件6、rmdir
删除目录7、ipconfig
查看IP8、ping
通讯测试9、start http://www.baidu.com
打开浏览器10、tasklist
查看进程11、taskkill /f /im chrome.exe
关闭进程12、cd
切换目录13、netstat -ano|find "8080"
查看指定端口
node repl开发模式
cmd下执行js文件
node index.js
NPM国内镜像设置
1、使用国内镜像源(靠谱,亲测可以下载mysql)
将 npm 的默认源替换为国内镜像源(如淘宝镜像),可以显著提升下载速度。
npm config set registry https://registry.npmmirror.com
验证是否生效:
npm config get registry
安装 mysql:
npm install mysql2、使用 cnpm
cnpm 是淘宝镜像提供的 npm 客户端,默认使用淘宝镜像源,适合国内开发者。
npm install -g cnpm --registry=https://registry.npmmirror.com
使用 cnpm 安装 mysql:
cnpm install mysql
NPM模块库、WEB应用和回调函数
npm常用命令
1、npm list
查看本地模块2、npm install mysql
安装mysql模块3、npm uninstall mysql
卸载mysql模块4、npm root
本地模块根目录5、npm root -g
本地服务器所有模块根目录6、npm update mysql
升级指定npm包
node中创建第一个应用(WEB服务)
1、加载http web模块
安装模块
npm install express//1、加载http web模块
const express = require('express');
const app = express();app.get('/', (req, res) => {res.writeHead(200, { 'Content-Type': 'text/html;charset=utf-8' });res.write("<h1>测试123</h1>");res.send(); // 使用 res.send() 发送响应
});app.listen(666, () => {console.log('server is running');
});
2、查找运行的端口号,找到对应的进程ID
3、根据进程ID找到对应的进程
4、访问:
http://localhost:666/
node回调函数
1、同步操作文件
// 加载fs file模块
const fs = require('fs')
file = 'test.txt'
//开始读取文件
console.log('准备读取文件');//正在读取文件
data = fs.readFileSync(file)
console.log(data.toString())//读取文件结束
console.log('程序执行结束')
2、异步操作文件
// 加载fs file模块
const fs = require('fs')
file = 'test.txt'
//开始读取文件
console.log('准备读取文件');//正在读取文件
fs.readFile(file,function(err,data){console.log(data.toString())
});//读取文件结束
console.log('程序执行结束')
Event事件、模块、函数和路由
event事件循环
const events = require('events'); // 导入 events 模块
const evt = new events.EventEmitter(); // 初始化 EventEmitter 实例function eventHandler() {console.log('123'); // 事件处理函数
}evt.on('eventName', eventHandler); // 监听事件
evt.emit('eventName'); // 触发事件
模块系统
######show.js代码块// 自定义show模块
//函数里含有this,则该函数可以称为类
function show(){this.name = 'user1';this.say = function(){console.log('my name is ' + this.name);}
}// 导出show模块,然后在index.js中引入使用
module.exports = show;######index.js代码块使用
const show = require('./show.js');
obj = new show();
obj.say();
function函数
1、常用函数
function aa(){console.log(123);
}
2、匿名函数
aa = function(){console.log(123);
}
路由
const http = require('http');
const url = require('url');cs = function(req,res){res.writeHead(200,{'Content-Type':'text/plain;utf-8'});uri = req.url;if(uri != '/favicon.ico'){//解析路由path = url.parse(uri,true).pathname;switch(path){case '/user/add':res.write('add');break;case '/user/list':res.write('list');break;default:res.write('404');}}res.end();
}http.createServer(cs).listen(8888);
NodeJS全局对象
node全局对象:
console.log(__filename);console.log(__dirname);setTimeout(function(){
console.log(123)
},1000)setTimeout(function(){
console.log(123)
},1000)console.log()计算程序执行时间
const start = performance.now();
for(let i = 0; i < 100000000; i++) {// 空循环
}
const end = performance.now();
console.log(`Execution time: ${end - start} milliseconds`);查看进程相信信息
str = process.version;
str = process.arch;
console.log(str);
NodeJS文件系统、GET请求和工具模块
文件系统
1、读文件内容
1)异步读取
readFile()
##示例:
//加载文件处理模块
const fs = require('fs');
file = 'test.txt';
//同步读取
fs.readFile(file,function(err,data){str = data.toString();console.log(str);
})
console.log('读取文件内容');2)同步阻塞读取
readFileSync()
##示例:
//加载文件处理模块
const fs = require('fs');
file = 'test.txt';
//同步读取
data = fs.readFileSync(file)
str = data.toString();
console.log(str);2、写文件内容
const fs = require('fs');
const file = 'test.txt';
const str = '\n11111';fs.appendFile(file, str, 'utf8', (err) => {if (err) {console.error('追加文件内容时出错:', err);} else {console.log('内容追加成功');}
});
3、删除文件
unlink()
##示例:
const fs = require('fs');
const file = 'test.txt';if (fs.existsSync(file)) {fs.unlink(file, (err) => {if (err) {console.error('删除文件时出错:', err);} else {console.log('文件删除成功');}});
} else {console.log('文件不存在');
}
4、创建目录
mkdir()
##示例:
const fs = require('fs');
const dir = 'myweb';
if (!fs.existsSync(dir)) {fs.mkdir(dir, (err) => {if (err) {console.error('创建目录时出错:', err);} else {console.log('目录创建成功');}});
} else {console.log('目录已存在');
}
5、删除目录
rmdir()
get请求
http = require('http');
url = require('url');
querystring = require('querystring');cs = function(req,res) {uri = req.urlif(uri !='/favicon.ico'){str = url.parse(uri).query;json = querystring.parse(str);console.log(json);res.write(JSON.stringify(json));}res.end();
}http.createServer(cs).listen(8000);
console.log('server is running');
工具模块
##os模块
const os = require('os');
console.log(os.platform())##path模块
const path = require('path');
str = '/user/local/www/index.sh';
console.log(path.extname(str))
实战
1、php操作删除数据库
index.php
<?php
// 创建连接
$conn = new mysqli("localhost", "root", "root", "myweb");
// 检查连接是否成功
if ($conn->connect_error) {die("连接失败: " . $conn->connect_error);
}// 设置字符集
$conn->set_charset("utf8");// 执行查询
$sql = "SELECT * FROM user";
$ret = $conn->query($sql);// 检查查询结果
if (!$ret) {echo "查询失败: " . $conn->error;
}// 关闭连接
$conn->close();
?>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>*{font-family: 微软雅黑;}</style><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/css/bootstrap.min.css" integrity="sha384-B0vP5xmATw1+K9KRQjQERJvTumQW0nPEzvF6L/Z6nronJ3oUOFUFpCjEUQouq2+l" crossorigin="anonymous"><script src="https://code.jquery.com/jquery-3.5.1.min.js"></script><script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.1/dist/umd/popper.min.js" integrity="sha384-9/reFTGAW83EW2RDu2S0VKaIzap3H66lZH81PoYlFhbGU+6BZp6G7niu735Sk7lN" crossorigin="anonymous"></script><script src="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/js/bootstrap.min.js" integrity="sha384-+YQ4JLhjyBLPDQt//I+STsc9iw4uQqACwlvpslubQzn4u2UU2UFM80nGisd026JF" crossorigin="anonymous"></script>
</head>
<body><div class="container"><h2 class="page-header">查看用户:</h2><table class="table table-bordered table-hover"><tr><th>编号</th><th>用户名</th><th>密码</th><th>删除</th></tr><?php while ($row = $ret->fetch_assoc()) {echo "<tr>";echo "<td>" . $row["id"] . "</td>";echo "<td>" . $row["username"] . "</td>";echo "<td>" . $row["password"] . "</td>";echo "<td><a href='#' class='del' id='{$row['id']}'>删除</></td>";echo "</tr>";}?></table></div>
</body>
<script>$('.del').click(function(){let id = $(this).attr('id');let row = $(this).closest('tr'); // 保存当前行的引用$.get('del.php',{id:id},function(data){if(data == 1){row.hide(); }else{alert('删除失败');}})})
</script>
</html>
del.php
<?php
// 创建连接
$conn = new mysqli("localhost", "root", "root", "myweb");
// 检查连接是否成功
if ($conn->connect_error) {die("连接失败: " . $conn->connect_error);
}// 设置字符集
$conn->set_charset("utf8");// 执行查询
$id = $_GET['id'];
$sql = "DELETE FROM user WHERE id = {$id}";
$ret = $conn->query($sql);// 检查查询结果
if (!$ret) {echo "删除失败: " . $conn->error;
}else{echo 1;
}// 关闭连接
$conn->close();
2、node操作删除数据库
index.php
<?php
// 创建连接
$conn = new mysqli("localhost", "root", "root", "myweb");
// 检查连接是否成功
if ($conn->connect_error) {die("连接失败: " . $conn->connect_error);
}// 设置字符集
$conn->set_charset("utf8");// 执行查询
$sql = "SELECT * FROM user";
$ret = $conn->query($sql);// 检查查询结果
if (!$ret) {echo "查询失败: " . $conn->error;
}// 关闭连接
$conn->close();
?>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>*{font-family: 微软雅黑;}</style><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/css/bootstrap.min.css" integrity="sha384-B0vP5xmATw1+K9KRQjQERJvTumQW0nPEzvF6L/Z6nronJ3oUOFUFpCjEUQouq2+l" crossorigin="anonymous"><script src="https://code.jquery.com/jquery-3.5.1.min.js"></script><script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.1/dist/umd/popper.min.js" integrity="sha384-9/reFTGAW83EW2RDu2S0VKaIzap3H66lZH81PoYlFhbGU+6BZp6G7niu735Sk7lN" crossorigin="anonymous"></script><script src="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/js/bootstrap.min.js" integrity="sha384-+YQ4JLhjyBLPDQt//I+STsc9iw4uQqACwlvpslubQzn4u2UU2UFM80nGisd026JF" crossorigin="anonymous"></script>
</head>
<body><div class="container"><h2 class="page-header">查看用户:</h2><table class="table table-bordered table-hover"><tr><th>编号</th><th>用户名</th><th>密码</th><th>删除</th></tr><?php while ($row = $ret->fetch_assoc()) {echo "<tr>";echo "<td>" . $row["id"] . "</td>";echo "<td>" . $row["username"] . "</td>";echo "<td>" . $row["password"] . "</td>";echo "<td><a href='#' class='del' id='{$row['id']}'>删除</></td>";echo "</tr>";}?></table></div>
</body>
<script>$('.del').click(function(){let id = $(this).attr('id');let row = $(this).closest('tr'); // 保存当前行的引用$.getJSON('http://localhost:8888?cb=?', {id:id}, function(json){if(json.ok == 1){row.remove(); // 删除当前行}else{alert('删除失败');}})})
</script>
</html>
index.js
const http = require('http');
const url = require('url');
const querystring = require('querystring');
const mysql = require('mysql');const cs = function (req, res) {const uri = req.url; // 获取请求的 URLconst parsedUrl = url.parse(uri); // 解析 URLconst json = querystring.parse(parsedUrl.query); // 解析查询字符串fname = json.cb;id = json.id;jsonstr = fname + '({"ok":"1"})';//连接操作数据库const connection = mysql.createConnection({host: 'localhost',user: 'root',password: 'root',database: 'myweb'});connection.connect();connection.query('DELETE FROM user WHERE id = ?', [id], function (error, rs, fields) {if(rs.affectedRows == 1){res.write(jsonstr);res.end();}});//关闭数据库connection.end();
};http.createServer(cs).listen(8888);
相关文章:

NodeJS学习笔记
NodeJS软件安装 node环境安装: https://nodejs.org 安装好后的node通常在C:\Program Files\nodejs验证安装是否成功 node -v npm -v 进入REPL模式命令行模式 nodeNodeJS在REPL模式和编辑器使用 windos在dos下常用命令 windos命令: 1、cmd dos系统2、…...

【交通网络拓扑图实现原理深度解析】
交通网络拓扑图实现原理深度解析 简易demo地址 背景故事:交通网络调度可视化的演进 1. 项目背景 在现代城市轨道交通系统中,交通网络线路的可视化展示一直是一个重要而复杂的问题。传统的交通网络线路图往往采用静态图片方式展示,这种方式…...

【极客时间】浏览器工作原理与实践-2 宏观视角下的浏览器 (6讲) - 2.6 渲染流程(下):HTML、CSS和JavaScript,是如何变成页面的?
https://time.geekbang.org/column/article/118826 2.6 渲染流程(下):HTML、CSS和JavaScript,是如何变成页面的? 2.5介绍了渲染流水线中的 DOM 生成、样式计算和布局三个阶段,2.6讲解渲染流水线后面的阶段…...

NO2.C++语言基础|C++和Java|常量|重载重写重定义|构造函数|强制转换|指针和引用|野指针和悬空指针|const修饰指针|函数指针(C++)
6. C 和 Java 区别(语⾔特性,垃圾回收,应⽤场景等) 指针: Java 语⾔让程序员没法找到指针来直接访问内存,没有指针的概念,并有内存的⾃动管理功能,从⽽有效的防⽌了 C 语⾔中的指针…...

【CSS】---- 纯 CSS 实现无限滚动轮播
1. 前言 仅使用 CSS 创建一个具有无限滚动轮播的动画,无需 JavaScript。首先是无限滚动轮播动画效果在我们常见的开发中都是借用 JavaScript 实现,如果纯粹使用 CSS,我觉得还是一个比较有趣的。 2. 效果预览 3. 效果分析 一屏展示了三个图片元素;动画依次向左移动;三个图…...

软考架构师笔记-计算机网络
1.9 计算机网络 OSI/RM 七层模型 物理层 二进制传输(中继器、集线器) (typedef) 数据链路层 传送以帧为单位的信息(网桥、交换机、网卡) 网络层 分组传输和路由选择(三层交换机、路由器)ARP/RARP/IGMP/ICMP/IP 传输层 端到端的连接(TCP/UDP)在前向纠错系统中,当接…...

Spring MVC 页面重定向返回后通过nginx代理 丢失端口号问题处理
Spring MVC页面重定向通过Nginx代理后出现端口丢失问题,通常由以下原因及解决方案构成: ## 一、Nginx配置问题(核心原因) 1. Host头传递不完整 Nginx默认未将原始请求的端口信息传递给后端,导致应用生成重定向…...

道可云人工智能每日资讯|亚马逊云业务部门成立智能体人工智能团队
道可云元宇宙每日简报(2025年3月6日)讯,今日元宇宙新鲜事有: 《杭州市富阳区未来产业培育行动计划(2025-2026年)》发布 3月3日,杭州市富阳区经信局正式发布了《杭州市富阳区未来产业培育行动计划(2025-2026年)》&…...

算力100问☞第72问:算力与算法、数据的关系是什么?
目录 1、数据是基础 2、算法是核心 3、算力是保障 4、三者的关系 5、实际应用中的体现 算力、算法和数据是人工智能和计算机科学领域的三个核心要素,它们之间相互依赖、相互促进,共同构成了现代计算系统的基础。以下是它们之间的关系: 1、数据是基础 定义:数据是信息…...
AI-Ollama本地大语言模型运行框架与Ollama javascript接入
1.Ollama Ollama 是一个开源的大型语言模型(LLM)平台,旨在让用户能够轻松地在本地运行、管理和与大型语言模型进行交互。 Ollama 提供了一个简单的方式来加载和使用各种预训练的语言模型,支持文本生成、翻译、代码编写、问答等多种…...

Java开发的AI应用框架简述——LangChain4j、Spring AI、Agent-Flex
LangChain4j LangChain4j官网 star很多,文档齐全,在AI服务中,提供了丰富的功能,示例代码丰富。 简介 是一个功能丰富、易于使用的Java AI开发框架,特别适合需要快速集成和使用大型语言模型的Java开发者。 项目特点 …...

【算法day2】无重复字符的最长子串 两数之和
无重复字符的最长子串 给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。 https://leetcode.cn/problems/longest-substring-without-repeating-characters/ class Solution { public:int lengthOfLongestSubstring(string s) {int sub_length …...

HarmonyOS:基于hmrouter实现Page的生命周期监听
前言:在使用ArkTs语言写鸿蒙的App中,我们发现Page的生命周期函数,如下: 页面的生命周期(32) onPageShow:页面显示触发(页面特有) onPageHide:页面隐藏触发(页面特有) onBackPress:当用户点击返回按钮时…...

DeepSeek + 飞书多维表格搭建你的高效工作流
众所周知,大模型DeepSeek擅长于处理大规模语言模型推理任务,特别是在成本降低和思维链推理方面表现出色,我们一般把大模型必做我们的大脑,但是一个人不能只有大脑,还需要其他输入输出以及操作支配的眼耳鼻嘴手足等。…...

uniapp+<script setup lang=“ts“>使用 uni.$emit和uni.$on全局传递数据
注意: 在A页面直接使用 uni.$emit(changeCategoryKey, childCategory)传递,在B页面使用 uni.$on(changeCategoryKey, (val) > {console.log(val, 取值);});只在组件传递有效,页面跳转后是无效的 跳转页面使用的传递数据的方法如下&…...

综合使用pandas、numpy、matplotlib、seaborn库做数据分析、挖掘、可视化项目
目录 1.结构化数据挖掘 1.1依赖库导入和数据读取 1.2各品牌机型及售价统计 1.3视频录制规格与价格关联性分析 2.结构化数据预处理 2.1筛选特征 2.2特征标签归一化及编码 1.结构化数据挖掘 1.1依赖库导入和数据读取 导入必要的依赖库,读取 csv 格式数据集转化为 Data…...

docker中kibana启动后,通过浏览器访问,出现server is not ready yet
问题:当我在浏览器访问kibana时,浏览器给我报了server is not ready yet. 在网上试了很多方法,都未能解决,下面是我的方法: 查看kibana日志: docker logs -f kibana从控制台打印的日志可以发现ÿ…...

十、Redis 主从复制:原理解析、配置实践与优化策略
Redis 主从复制:原理解析、配置实践与优化策略 Redis 作为高性能的 NoSQL 数据库,主从复制(Master-Slave Replication) 是其核心特性之一。主从复制用于数据冗余、读负载分担、故障恢复,是 Redis 构建高可用架构的基础。本文将深入解析 Redis 主从复制的配置方法、复制机…...

使用JMeter(组件详细介绍+使用方式及步骤)
JSON操作符 在我们使用请求时,经常会遇到JSON格式的请求体,所以在介绍组件之前我会将介绍部分操作符,在进行操作时是很重要的 Operator Description $ 表示根元素 当前元素 * 通配符,所有节点 .. 选择所有符合条件的节点 .name 子元素,name是子元素名称 [start:e…...

lamp平台的应用
一.lamp介绍 网站: 静态网站 动态网站 【php语言 .php结尾的文件】 作用:运行php语言编写的动态网站应用 lamp LinuxApache【负责解析静态资源】MySQL【负责存储网站产生的数据】PHP【负责解析动态资源】 如上图所示,是lamp平台中三…...

蓝桥杯4T平台(串口打印电压值)
知识点:串口(单片机发送数据)按键ADC 题目 配置 代码 adc.c uint16_t getadc2(void) {uint16_t adc0;HAL_ADC_Start(&hadc2);adcHAL_ADC_GetValue(&hadc2);return adc; } adc.h uint16_t getadc2(void); main.c #include "lcd.h" #include…...

使用ASIWebPageRequest库编写Objective-C下载器程序
使用 ASIWebPageRequest 库编写 Objective-C 下载器程序是一个简单且高效的方式来处理 HTTP 请求。在 ASIHTTPRequest 和 ASIWebPageRequest 中,ASIWebPageRequest 是专门用于下载网页及其资源的库。 1. 安装 ASIWebPageRequest 首先,你需要安装 ASIHT…...

代码随想录算法训练营 | 图论 | 孤岛总面积、沉没孤岛
101. 孤岛的总面积//思路大概是先计算面积,然后如果有接触路面就返回false。可能稍微多余算了太多无用面积。 #include<bits/stdc.h> using namespace std; void sum(vector<vector<bool>>& finded,const vector<vector<int>>&a…...

迷你世界脚本出生点接口:Spawnport
出生点接口:Spawnport 彼得兔 更新时间: 2023-04-26 10:19:56 具体函数名及描述如下: 序号 函数名 函数描述 1 getSpawnPoint(...) 获取默认出生点 2 setSpawnPoint(...) 设置出生点位置 3 getChunkValidSpawnPos(...) 获取区块有效刷新点…...

双链路提升网络传输的可靠性扩展可用带宽
为了提升网络传输的可靠性或增加网络可用带宽, 通常使用双链路冗余备份或者双链路聚合的方式。 本文介绍几种双链路网络通信的案例。 5GWiFi冗余传输 双Socket绑定不同网络接口:通过Android的ConnectivityManager绑定5G蜂窝网络和WiFi的Socket连接&…...

Pytest测试用例执行跳过的3种方式
文章目录 1.前言2.使用 pytest.mark.skip 标记无条件跳过3.使用 pytest.mark.skipif 标记根据条件跳过4. 执行pytest.skip()方法跳过测试用例 1.前言 在实际场景中,我们可能某条测试用例没写完,代码执行时会报错,或者是在一些条件下不让某些…...

【蓝桥杯】每天一题,理解逻辑(3/90)【Leetcode 快乐数】
闲话系列:每日一题,秃头有我,Hello!!!!!,我是IF‘Maxue,欢迎大佬们来参观我写的蓝桥杯系列,我好久没有更新博客了,因为up猪我寒假用自己的劳动换了…...

深度学习Save Best、Early Stop
一、Save Best 今天的大模型,在训练过程中可能会终止,但是模型其实是可以接着练的,假设GPU挂了,可以接着训练,在原有的权重上,训练其实就是更新w,如果前面对w进行了存档,那么可以从…...

数据库与存储优化
一、MySQL深度优化 索引优化 B树索引结构 结构特点: 平衡多路搜索树,所有数据存储在叶子节点,非叶子节点仅存键值和指针。叶子节点通过双向链表连接,支持范围查询高效遍历。 优势: 减少磁盘IO(高扇出&#…...

Android15请求动态申请存储权限完整示例
效果: 1.修改AndroidManifest.xml增加如下内容: <uses-permission android:name="android.permission.MANAGE_EXTERNAL_STORAGE" /><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /><uses-perm...