node.js考试复习资料2
创始人
2025-05-28 12:11:50
0

一.AJAX

1.什么是AJAX?

Ajax 的全称是 Asynchronous JavaScript And XML(异步 JavaScript 和 xml

通俗理解:在网页中利用 XMLHttpRequest 对象和服务器进行数据交互的方式,就是Ajax

2.AJAX发生请求,传递参数

get方式:

// 1.创建请求对象
let xhr = new XMLHttpRequest();
// 2.调用open方法,设置请求方式和请求地址
xhr.open( 'get','https://autumnfish.cn/api/joke/lis
?num=10)
// 3.设置请求成功后执行的回调函数
xhr.onload = function()(
// console.log(xhr.response);
// console.log(xhr.response);
let obj = JSON.parse(xhr.response.
console.log(obj);
}
// 4.调用send方法
xhr.send( );

POST方式

// 1.实例化ajax对象
let xhr = new XMLHttpRequest();
// 2.设置请求方法和地址
//(用户注册)
xhr.open( 'post','https://autumnfish.cn/api/user/register')
// 3.设置请求头 (post请求才需要设置)
xhr.setRequestHeader("Content-type","application/x-www-form-urlenco
// 4.注册回调函数
xhr.onload = function(){
console.log(xhr.responseText);
5.发送请求:参数格式key = value
hr.send('username= lyz')

二.数组迭代

map数组迭代

应用场景:遍历每一个元素,并对每一个元素做响应的处理,返回一个新数组

    let arr = [23,31,60,88,108,206];//需求:数组中每一个元素+1let arr1 = arr.map((value,index) => {return value + 1; //让每一个元素的值+1})console.log(arr1); //[24, 32, 61, 89, 109, 207]

注意点:

a.回调函数执行次数 = 数组长度 (数组中有几个元素,回调函数就会执行几次)

b.map函数返回的新数组长度 == 原数组长度
c.回调函数中一定要return,返回的是当前遍历的元素值(如果不return,新数组中的每一个元素都变成了undefined)

filter数组迭代

应用场景:筛选数组中满足条件的元素,返回筛选后的新数组

let arr = [3,31,60,-88,90,-108,260]
// 求数组中大于10的所有元素
let nArr = arr.filter(function(value){// 筛选条件
return value > 10
// nArr里保存的是所有满足条件的元素
console.log(nArr); //[31,60,90,260]

注意点:

 a.回调函数执行次数 == 数组长度
 b.filter函数返回的新数组长度 ! = 原数组长度

forEach数组迭代

应用场景:遍历数组,相当于for循环另一种写法

let arr = [23,31, 60,88,90,108,260];
// 对数组进行累加
let sum = 0
arr.forEach(function(value){sum += value
})
console.log(sum); //660

注意点

a.回调函数执行次数 == 数组长度(数组中有多少元素,回调函数就会执行几次)
b.forEach函数没有返回值

c.回调函数不需要return(就算手动ruturn,也不会结束循环)

 forEach和map方法有什么区别?

forEach()方法不会返回执行结果,也就是说forEach()方法会修改原来的数组,但是没有返回值。 map()方法得到一个新的数组,是map方法修改数组后返回来的新数组。

some:判断数组中是否有元素符合给定条件 

应用场景:用于判断数组中是否存在满足条件的元素

let arr = [23,31,60,88,0,90,108,260]
let arr1 = arr.some((item,index)
return item < 0
});
console.log(arr1);

注意点:

a.回调函数执行次数 ! = 数组长度 

b.some函数返回一个布尔类型值

c.回调函数返回布尔类型值用于结束遍历

return true; 遍历结束,且some函数返回值为true。

return false; 遍历继续,且some函数返回值为true

every判断是否所有元素符合过滤条件 

应用场景:判断数组中是否所有元素都满足条件

let arr = [23,31,60,88,-50,90,108,260];
let arr1 = arr.every((item) =>{
return item > 0;
});
console.log(arr1); //false

注意点:every函数返回一个布尔类型值

 findIndex返回第一个匹配的元素位置

应用场景:适合于数组中元素为对象类型,比传统for循环要高效

let arr = [
{ name:张三 ,age:20 },
{name:'李四',age:30 },
{name:'王五',age:25 },
{name:'赵六 ,age:33 },
{name:'小七',age:10 },
]
//查找arr1中第一个未成年在什么位置
let res = arr.findIndex( (item,index) =>{
return item.age < 18;
})
console.log(res); //4

reduce数组操作

应用场景:数组求和/平均数/最大值/最小值

let arr1 = [20,55,80,70,92,35];
let res1 = arr1.reduce((sum,value) => 
return sum + value;
console.log( res1); //352

注意点:最好给一个初始值,避免空数组报错

三. npm包管理

npm instal 模块名: 本地安装。安装到当前项目的node_modules目录下,只有当前项目可以用此依赖.
npm install 模块名  -g: 全局安装。电脑上的任何项目都可以使用这个依赖。
npm install 模块名 -save: 安装到node modules目录下,一般安装生产环境所用依赖。如vue,element-u

npm install 模块名 -save -dev: 安装到node modules目录下,一般安装开发环境所用依赖。如webpack.

四.math对象 

1.圆周率: Math.PI
 console.og(Math.PI); //3.141592653589793
 2.绝对值: Math.abs()
 console.log(Math.abs(-2)); //2
 3.找最大值/最小值: Math.max() Math.min()

 console.log(Math.max(1,2,3)); //3

 console.log(Math.min(1,2,3)); //1

 4.0-1随机小数: Math.random
console.log(Math.random());
5.幂运算: Math.pow(x,y)
console.log(Math.pow(2,3)); //8

6.向上取整/向下取整: Math.ceil() Math.floor()

console.log(Math.ceil(1.2)); //2

console.log(Math.floor(1.8)); //1

五. cookie

应用场景:记录用户浏览数据,进行商品(广告)推荐

特点:

cookie保存在浏览器端。
单个cookie保存的数据不能超过4KB.
cookie中的数据是以域名的形式进行区分的。
cookie中的数据是有过期时间的,超过时间数据会被浏览器自动删除

cookie中的数据会随着请求被自动发送到服务器端。

六. localstorage

什么是localstorage?

在HTML5中,加入了一个localstorage特性作为本地存储来使用。它解决了cookie存储空间不足的问题,每条cookie的存储空间为4K,localStorage一般为5M。

localstorage的生命周期:

LocalStorage生命周期是永久,这意味着除非用户在显示在浏览器提供的UI上清除LocalStorage信息,否则这些信息将永久存在。

什么是SessionStorage?

为每一个数据源维持一个存储区域,在浏览器打开期间存在,包括页面的重新加载。关闭浏览器之后就会消失。

SessionStorage的生命周期:

SessionStorage生命周期为当前窗口或标签页
一旦窗口或标签页被永久关闭了,那么所有通过Session存储的数据也就被清空了

七.内置fs模块 

fs模块作用: node提供了一个内置模块叫fs(filesystem),专门用来操作文件的。

可以读取一个文件的内容,也可以把内容写入到一个文件。

读取文件内容我们首先需要引入 fs模块:

const fs = require('fs')
注意:fs里面的方法是异步

文件的读取:fs.readFile()

  //读取文件
  fs.readFile(path[,options],callback)({
     //不管是读取成功,还是读取失败,都会调用这个回调函数。
      //如果读取失败,err里就会有错误信息。 
      // 如果读取成功,err为空,data里就会有读取的内容
        })

  • 参数1:path必选参数,字符串,表示文件的路径。
  • 参数2:options可选参数,表示以什么编码格式来读取文件。
  • 参数3:必选参数,文件读取完成后,通过回调函数拿到读取的结果。

文件的写入:fs.writeFile()

fs.writeFile(filename,data[,options],callback)

  • 参数1:filename必选参数,需要指定一个文件路径的字符串,表示文件的存放路径。
  • 参数2:data必选参数,表示要写入的内容。
  • 参数3:可选参数,表示以什么格式写入文件内容,默认值是utf8。
  • 参数4:callback必选参数,文件写入完成后的回调函数。

追加文件内容:fs.appendFile()

  //追加文件内容 
      fs.appendFile('路径','要追加的内容',err => { 
        if(!err){
         console.log('追加成功'); 
         }
         })

拷贝的文件:fs.copyFile()

   // 拷贝文件 
   fs.copyFile('要拷贝的文件路径','目标文件的路径')

文件的创建:fs.mkdir()

function createDirectory(){
    fs.mkdir('../files/ff',()=>{
        console.log('创建文件夹成功')
    })
}

删除文件夹:fs.rmdir()

function deleteDirectory(){
    fs.rmdir('../files/ff',()=>{
        console.log('删除文件夹成功')
    })
}

相关内容

热门资讯

黄金“不灵了”,高端金饰的溢价... 古法黄金到底能不能走出脱离金价波动的独立溢价 作者:赵心怡 2026年开年,国际金价一路狂飙至近56...
朗迅科技由董事长徐振控制46%... 瑞财经 刘治颖 6月24日,杭州朗迅科技股份有限公司(以下简称:朗迅科技)深主板IPO获受理,保荐机...
两部门:2030年可再生能源制... 【两部门:2030年可再生能源制氢规模达到200万吨】财联社6月25日电,国家发展改革委、国家能源局...
原创 警... 大家好,这里是全球脉冲。 6月16日,日本央行宣布加息25个基点,政策利率上调至1%,创下31年来最...
黄金钻石回收怎么选?上海市场常... 近年来黄金价格持续走高,不少上海市民都有变现家中闲置黄金首饰、投资金条的打算。但市面上回收门店数量众...
专访火山引擎谭待:模型好对Ma... 文 | 邓咏仪 编辑 | 张雨忻 火山引擎总裁谭待 来源:火山引擎 过去三年,火山引擎总裁谭待给团...
女董事长深夜被带走,牵出金融旧... *此图由AI生成 作者| 史大郎&猫哥 来源| 是史大郎&大猫财经Pro 大半夜的,一家上市公司董事...
盯盯拍报考港交所上市:出海翻红... 撰稿|贝多 来源|贝多商业&贝多财经 6月22日,盯盯拍(深圳)技术股份有限公司(下称“盯盯拍”)递...
苏州千亿市值上市公司+1! A股“苏州板块”又诞生了一家千亿市值企业。 昨日(6月25日),苏州上市公司永鼎股份股价在昨日涨停的...
芯片股猛拉!600667,一字... 【导读】创业板指一度涨超2%,存储芯片、半导体、电子元器件等方向涨幅居前 中国基金报记者 李智 一起...
分析师:海峡收费与否已不重要 ... 来源:格隆汇APP 格隆汇6月25日|阿曼方面重申,霍尔木兹海峡未来安排不涉及通行费。美国财经网站i...
《内外贸一体化企业评价通则》团... 齐鲁晚报·齐鲁壹点记者 管悦 6月25日,《内外贸一体化企业评价通则》团体标准审查会在济南召开。该标...
提升AI智能体工作流的速度与能... 智能体工作流是一种由AI驱动的软件系统,它通过串联多个模型与外部工具来处理复杂任务,例如分析视频并回...
热搜!又有纸尿裤被曝检出甲酰胺... 来源:市场资讯 (来源:北京商报) 网友:“囤了200多包”。 近日,多个婴幼儿纸尿裤品牌“被检出...
埃森哲内部录音曝光:企业AI使... IT之家 6 月 26 日消息,科技媒体 404Media 昨日(6 月 25 日)发布博文,披露了...
FIBA期待杨瀚森表现 最新实... 北京时间6月25日消息,FIBA国际篮联公布了最新一期世界杯预选赛亚太区球队实力榜,中国男篮排在澳大...
收评:创业板指放量反弹涨2.8... 市场冲高回落后,再度震荡拉升。黄白线分化明显,权重股走势较强。量能明显放大,沪深两市成交额3.59万...
巨头财报引爆A股存储芯片板块,... 当地时间6月24日美股盘后, 美光科技(MU.US)公布截至5月31日的2026财年第三财季财报,业...
银行、消金公司助贷余额增速不得... 近日,中国证券报记者从多位业内人士处独家获悉,5月以来,多地金融监管部门对部分中小银行、消金公司下达...