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('删除文件夹成功')
    })
}

相关内容

热门资讯

刚刚,大跳水!超42万人爆仓!... 来源:券商中国 加密货币,遭遇抛售潮! 凯文·沃什被提名为下一任美联储主席所产生的后续效应,正持续波...
做好银行网点“加减法” 国家金融监督管理总局网站披露的信息显示,2025年共有约1.1万家银行业金融机构的线下网点获准退出,...
金价暴跌引热议,网友:商场门口... 来源:中国基金报 随着国际金价急速下跌,国内首饰金价也迎来大幅回调。 1月31日,老庙报1546元/...
内蒙古一银行员工将储户220万... 内蒙古一银行员工将储户220万元存款转走并挥霍,银行称员工已离岗不愿承担赔偿 1月31日,有媒体报...
老年医学科进修轶事|老年医学如... 和年苑,北京协和医院老年医学科公众号,传递老年医学的价值和声音 在这里,了解当代老年医学 Autum...
和讯投顾余兴栋:周五杀跌,下周... 周五大盘大幅度的杀跌又探底回升,收出一根长长的下影线,不少的朋友又在问我,那这根k线是不是就意味着调...
【数智周报】马化腾评豆包手机;... 【数智周报将整合本周最重要的企业级服务、云计算、大数据领域的前沿趋势、重磅政策及行研报告。】 观点马...
和美字节,用字节连接和美 和美字节(Hemei Byte),是杭州桑桥网络科技有限公司于 2026 年 1 月完成品牌升级后启...
仙乐健康56岁副总姚壮民业务员... 瑞财经 刘治颖 1月29日,仙乐健康科技股份有限公司(以下简称:仙乐健康)向港交所主板递交上市申请书...
詹姆斯下家概率:骑士最高退役第... 近日,有关詹姆斯的未来引发了大众的热议,相关机构也更新了这位巨星的下家概率,回归骑士是最大可能。 相...
原创 猛... 在国际金价屡创历史新高之时,资本市场正经历一场有趣的分化:有人急于套现离场,有人却大举加码。近日,一...
原创 男... 在爱情的海洋中,星座与情感交织出无数动人的故事。当一个男性用以下这四个称呼来称呼你时,他的爱情之舟正...
民航持续回暖:南航、海航预计去... 时隔五年,南航预计在三大航中率先实现年度扭亏。 截至1月30日晚间,中国国航(601111.SH)、...
公募加仓非银金融,后市机会如何... 基金增配保险、券商股。 最新数据显示,公募基金2025年四季度的非银金融仓位提高1个百分点。继有色金...
赵慧芳主任中医治疗产后“月子病... 赵慧芳主任中医治疗产后“月子病”的临床智慧 产后调理是中华民族传承千年的养生智慧,在中医理论中占据重...
江西万年青水泥股份有限公司20... 本公司及董事会全体成员保证信息披露的内容真实、准确、完整,没有虚假记载、误导性陈述或重大遗漏。 一、...
科学应对甲状腺结节,别让“结节... 随着健康意识的提升 超声检查在体检中普及率不断提高 甲状腺结节的检出率也显著上升 不少人拿着“结节”...
春节前,政府债发行提速 来源:郁言债市 01 1月资金面,两轮波动,中枢平稳 回顾开年以来资金利率走势,月内资金经历两轮波动...
【央行多措并举护航,专家预期节... 【央行多措并举护航,专家预期节前流动性保持充裕】1月29日,中国人民银行以固定利率、数量招标方式开展...
季节性因素叠加市场需求不足,1... 来源:界面新闻 记者 辛圆 国家统计局周六公布数据显示,1月份,中国制造业采购经理人指数(PM...