Day10 5.5 Js 背 数组方法 扩展

本文详细介绍了JavaScript中的核心概念,包括原型链、作用域、闭包、this的指向,以及深拷贝、浅拷贝的区别。此外,还讲解了如何实现深拷贝,以及数组方法如push、pop、unshift、shift等的操作。文章最后讨论了数据类型判断的不同方法和JSONP的原理。
摘要由CSDN通过智能技术生成

js 面试题的四大金刚 必问的题

闭包 深拷贝浅拷贝 原型相关的 ajax 相关的

一、原型和原型链 ******

  1. prototype
    每个函数都有一个 prototype 属性,被称为显式原型,里面包含了这个构造函数公共的方法
    2._ proto _
    每个实例对象都会有_ proto 属性,其被称为隐式原型
    每一个实例对象的隐式原型
    proto _属性指向自身构造函数的显式原型 prototype
  2. constructor
    每个 prototype 原型都有一个 constructor 属性,指向它关联的构造函数。
  3. 原型链
    获取对象属性时,如果对象本身没有这个属性,那就会去他的原型_ proto 上去找,如果还查不到,就去找原型的原型,一直找到最顶层(Object.prototype)为止。Object.prototype 对象也有 proto _属性值为 null。

二、作用域 ***

1.作用域:
作用域就是一个变量可以使用的范围,主要分为全局作用域和函数作用域
全局作用域就是Js中最外层的作用域
函数作用域是js通过函数创建的一个独立作用域,函数可以嵌套,所以作用域也可以嵌套
Es6中新增了块级作用域(由大括号包裹,比如:if(){},for(){}等)
2.自由变量:
当前作用域外的变量都是自由变量,作用域链就是 自己没有这个变量就从上一级作用域查找,直到找到为止,直到找到顶层window,没有的话就报错
3.变量提升:
每个var声明的变量,function声明的函数存在变量提升。变量和函数都有声明提升,let const不存在变量提升
会把声明语句提到代码的最顶端,赋值语句留在原地等待执行
Var a=10 var a会被提升 a=10会留在原地
(在js中声明之前未定义,会在js的最上方会形成一个预解析池,用来存储声明了但没有先定义的变量名)

三、闭包 *****

闭包:

简单的理解就是函数中套了一个函数,内层函数可以访问外层函数中的变量
有时候需要用到函数内的局部变量,在正常情况下是不能读取到的,这个时候就需要用到闭包。
闭包可以封装对象的私有属性和方法,vue 中的 data 就是一种闭包的形式。
闭包作为回调函数,可以实现函数的复用
优点:闭包因为长期驻扎在内存中。可以重复使用变量,不会造成变量污染
缺点:闭包会使函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,可能会导致内存泄露。解决方法是在退出函数之前,将不使用的变量全部删除。

四、This 的指向 ****

在 js 中 this 不是固定不变的,它会随着执行环境的改变而改变。要注意的是 this 取什么值,是在执行时确认的,定义时无法确认。
this 的调用大概分为五种场景: 1.浏览器里,在全局范围内的 this 指向 window 对象; 2.在函数中,this 永远指向最后调用他的那个对象; 3.构造函数中,this 指向 new 出来的那个新的对象; 4.箭头函数中 this 比较特殊,箭头函数 this 为父作用域的 this,不是调用时的 this.要知道前四种方式,都是调用时确定,也

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值