常见知识点总结

文章目录

for of和for in

都是常见的循环结构,允许我们遍历对象的属性或数组、字符串、Map、Set等可迭代对象的元素。

for in循环遍历的是对象的属性名,而不是属性值;会枚举出对象自身以及原型链上的所有可枚举属性,(除非该对象使用Object.prototype的hasOwnProperty方法来过滤掉原型链上的属性)

for of循环用于遍历可迭代对象的元素,for of循环直接遍历的是值,而不是键

for of循环遍历的是可迭代对象的元素值,而不是属性名。

区别

for in遍历的是对象的属性名,for of遍历的是可迭代对象的元素值

for in会遍历对象自身以及原型链上的属性,而for of只遍历对象自身的元素

for in适用于普通对象,for of适用于可迭代对象(数组,字符串,Map,Set)

同源策略

源的定义:如果两个url的协议,端口,主机都相同,则这两个url是同源的

在浏览器中,同源策略(Same-origin_policy)是一个重要的安全策略。用于限制不同源之间的资源交互。

跨域资源共享

是一种基于 HTTP 头的机制,该机制通过允许服务器指定允许浏览器访问的源来加载自己的资源。是一种基于 HTTP 头的机制,该机制通过允许服务器指定允许浏览器访问的源来加载自己的资源。

跨域问题

不同源之间的资源交互,就会存在跨域问题。比如:请求的接口不同源导致跨域

解决跨域
jsonp

原理是利用script标签不受浏览器同源策略的限制,和后端一起解决跨域问题

具体:在客户端创建一个script标签,然后把请求后端的接口拼接一个回调函数名称作为参数传给后端,并且赋值给script标签的src属性,然后把script标签添加到body中,当后端收到客户端的请求时,会解析得到回调函数的名称,然后把数据和回调函数名称拼接成函数调用的形式返回

cors方式

cors是跨域资源共享,是一种http头的机制,该机制通过允许服务器标示除了它自己以外的其他origin(域,协议和端口),使得浏览器允许这些origin访问加载自己的资源,服务端设置了Access-Control-Allow-Origin就开启了cors

nginx代理方式

nginx通过反向代理解决跨域,利用了服务器请求服务器不受浏览器同源策略的限制实现的。

apply,bind,call

相同点
  1. apply 、 call 、bind 三者都是用来改变函数的this对象的指向;
  2. apply 、 call 、bind 三者都可以利用后续参数传参;
不同点

在接受参数方面:call和bind接收多个参数,apply接受一个数组

call/apply 会让函数执行的

call后面参数是依次逗号分隔传入

apply:一个参数数组,数组成员是依次传入

bind 不会执行前面的函数!返回值:新的函数 和原来那个函数长的一样,内部this已经被我们固定

js判断数据类型的方式

typeof

通常判断基本数据类型,返回表示数据类型的字符串

注意:使用typeof来判断null和引用类型的实例 返回的结果都是 'object'。

instanceof

a instanceof A ,判断参照对象(大写字母A)的prototype属性所指向的对象是否在被行测对象a的原型链上。

instanceof 只能用来判断两个对象是否属于实例关系,而不能判断一个对象实例具体属于哪种类型。

对于number,string,boolean这三种基本数据类型,只有通过构造函数才能检测出

constructor

constructor是原型对象的属性指向构造函数,可以检测出除了undefined和null的9种类型(因为它两没有原生构造函数)

Object下的toString.call()方法
Object.prototype.toString.call();
console.log(toString.call(123));          //[object Number]
console.log(toString.call('123'));        //[object String]
console.log(toString.call(undefined));    //[object Undefined]

闭包

闭包的作用

1.使用函数内部的变量在函数执行完以后,仍然存活在内存中(延长了局部变量的生命周期)

2.让函数外部可以操作(读写)到函数内部的数据(变量/函数)

注意

在函数外不能直接访问函数内部的局部变量

函数执行完之后,函数内部声明的局部变量一般不存在,存在于闭包中的变量才可能存在

闭包的生命周期

产生:在嵌套内部函数定义执行完时就产生了(不是在调用)

死亡:在嵌套的内部函数成为垃圾对象时

body-parser

中间件body-parser的作用是解析POST请求的请求体。然后我们可以通过req.body,获取到请求参数。

相关推荐
梓䈑8 分钟前
【C语言】自定义类型:结构体
c语言·开发语言·windows
f89790707018 分钟前
layui动态表格出现 横竖间隔线
前端·javascript·layui
鱼跃鹰飞25 分钟前
Leecode热题100-295.数据流中的中位数
java·服务器·开发语言·前端·算法·leetcode·面试
小蜗笔记31 分钟前
在Python中实现多目标优化问题(7)模拟退火算法的调用
开发语言·python·模拟退火算法
杨荧37 分钟前
【JAVA开源】基于Vue和SpringBoot的水果购物网站
java·开发语言·vue.js·spring boot·spring cloud·开源
知识分享小能手1 小时前
mysql学习教程,从入门到精通,SQL 修改表(ALTER TABLE 语句)(29)
大数据·开发语言·数据库·sql·学习·mysql·数据分析
魏大橙1 小时前
Fastjson反序列化
开发语言·python
cyz1410011 小时前
vue3+vite@4+ts+elementplus创建项目详解
开发语言·后端·rust
二十雨辰1 小时前
[uni-app]小兔鲜-04推荐+分类+详情
前端·javascript·uni-app