2020最全前端面试系列(JS)(前端进阶基础)

本文是2020年最全面的前端面试系列,聚焦JavaScript基础与进阶,涵盖数据类型、闭包、事件机制、事件代理、函数节流与防抖等核心概念。详细解析基本数据类型与引用数据类型的差异,探讨JavaScript中的this指向与异步编程。通过实例分析,帮助开发者巩固JS知识,为面试做好准备。
摘要由CSDN通过智能技术生成

2020最全前端面试系列(JS)(前端进阶基础)

数据类型

1. 基本数据类型和引用数据类型

基本数据类型: String, Number, Boolean, Null, Undefined, Symbol, Bigint
引用数据类型: Object, Array, Function, Regex

2. 基本数据类型和引用数据类型的区别,堆和栈的区别

基本数据类型(存放在栈中)
基本数据类型是指存放在栈中的简单数据段,数据大小确定,内存空间大小可以分配,它们是直接按值存放的,所以可以直接按值访问
引用数据类型(存放在堆内存中的对象,每个空间大小不一样,要根据情况进行特定的配置)
引用类型是存放在堆内存中的对象,变量其实是保存的在栈内存中的一个指针(保存的是堆内存中的引用地址),这个指针指向堆内存。
引用类型数据在栈内存中保存的实际上是对象在堆内存中的引用地址。通过这个引用地址可以快速查找到保存中堆内存中的对象

1、声明变量时内存分配不同
      原始类型:在栈中,因为占据空间是固定的,可以将他们存在较小的内存中-栈中,这样便于迅速查询变量的值
      引用类型:存在堆中,栈中存储的变量,只是用来查找堆中的引用地址。
      这是因为:引用值的大小会改变,所以不能把它放在栈中,否则会降低变量查寻的速度。相反,放在变量的栈空间中的值是该对象存储在堆中的地址。地址的大小是固定的,所以把它存储在栈中对变量性能无任何负面影响
 
2、不同的内存分配带来不同的访问机制

       在JavaScript中是不允许直接访问保存在堆内存中的对象的,所以在访问一个对象时,首先得到的是这个对象在堆内存中的地址,然后再按照这个地址去获得这个对象中的值,这就是传说中的按引用访问。
       而原始类型的值则是可以直接访问到的。

3、复制变量时的不同
1)原始值:在将一个保存着原始值的变量复制给另一个变量时,会将原始值的副本赋值给新变量,此后这两个变量是完全独立的,他们只是拥有相同的value而已。
2)引用值:在将一个保存着对象内存地址的变量复制给另一个变量时,会把这个内存地址赋值给新变量,
       也就是说这两个变量都指向了堆内存中的同一个对象,他们中任何一个作出的改变都会反映在另一个身上。(复制对象时并不会在堆内存中新生成一个一模一样的对象,只是多了一个保存指向这个对象指针的变量)

4、参数传递的不同(把实参复制给形参的过程)
       首先我们应该明确一点:ECMAScript中所有函数的参数都是按值来传递的。
       但是为什么涉及到原始类型与引用类型的值时仍然有区别呢?还不就是因为内存分配时的差别。  
1)原始值:只是把变量里的值传递给参数,之后参数和这个变量互不影响。
2)引用值:对象变量它里面的值是这个对象在堆内存中的内存地址.
       因此它传递的值也就是这个内存地址,这也就是为什么函数内部对这个参数的修改会体现在外部的原因了,因为它们都指向同一个对象。

3. 数据类型判断
  • typeof
    typeof 基本可以正常判断基本数据类型,没法正确识别 Null,可以区分function,但是对于其他引用数据类型会返回 Object,这是因为 typeof 的原理:

    • 所有数据类型在计算机中存储的都是按照“二进制”存储
    • Null -> 000000
    • 对象都以 000 开头
    • typeof 检测的时候,是按照计算机存储的二进制来检测的
typeof null		// "object"
typeof function(){
   }		// "function"
typeof []		// "object"
typeof  /./		// "object"
  • instanceof
    原理:根据原型对象来判断类型
function instanceof(left, right) {
   
    const rightVal = right.prototype
    const leftVal = left.__proto__
    // 若找不到就到一直循环到父类型或祖类型
    
  • 3
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值