JS基础面试题

1丶常见的基本数据类型:
Number、String 、Boolean、Null和Undefined。基本数据类型是按值访问的,因为可以直接操作保存在变量中的实际值。示例:

var a = 10;

  var b = a;

  b = 20;

  console.log(a); // 10值

上面,b获取的是a值得一份拷贝,虽然,两个变量的值相等,但是两个变量保存了两个不同的基本数据类型值。
b只是保存了a复制的一个副本。所以,b的改变,对a没有影响
在这里插入图片描述
2、引用类型数据:
也就是对象类型Object type,比如:Object 、Array 、Function 、Data等。
javascript的引用数据类型是保存在堆内存中的对象。
与其他语言的不同是,你不可以直接访问堆内存空间中的位置和操作堆内存空间。只能操作对象在栈内存中的引用地址。
所以,引用类型数据在栈内存中保存的实际上是对象在堆内存中的引用地址。通过这个引用地址可以快速查找到保存中堆内存中的对象。

var obj1 = new Object();

  var obj2 = obj1;

  obj2.name = "我有名字了";

  console.log(obj1.name); // 我有名字了

说明这两个引用数据类型指向了同一个堆内存对象。obj1赋值给onj2,实际上这个堆内存对象在栈内存的引用地址复制了一份给了obj2,

但是实际上他们共同指向了同一个堆内存对象。实际上改变的是堆内存对象。
  下面我们来演示这个引用数据类型赋值过程:
  在这里插入图片描述
3丶什么是深拷贝,浅拷贝,如何实现:
深拷贝和浅拷贝是针对复杂数据类型来说的,浅拷贝只拷贝一层,而深拷贝是层层拷贝。
浅拷贝:
浅拷贝是会将对象的每个属性进行依次复制,但是当对象的属性值是引用类型时。
实质复制的是其引用,当引用指向的值改变时也会跟着变化。
浅拷贝实现:
Object.assign
…扩展运算符
他跟递归和JSON.parse(JSON.stringify(obj))还不一样,就比如对象里面套一个对象,他只能拷贝第一层,这种情况下,他就不能实现深拷贝。
深拷贝:
深拷贝复制变量值,对于非基本类型的变量,则递归至基本类型变量后,再复制。
深拷贝后的对象与原来的对象是完全隔离的,互不影响, 对一个对象的修改并不会影响另一个对象。
深拷贝实现:
JSON.parse(JSON.stringify(obj))
递归等递归函数实现深拷贝。
递归函数实现:

let obj1 = {
  age: 18,
  name: "小胖",
  address: {
    city: "北京",
    a: {
     num:'1000'
    },
  },
  arr: ["a", "b", "c", "d", "e"],
};
let obj2 = deepClone(obj1);
obj2.address.city = "上海";
obj2.arr[2] = "h";
obj2.address.a.num='500'
console.log(obj1.address.a.num)
console.log(obj1.address.city);
/**
 * 深拷贝
 */
function deepClone(obj = {}) {
  if (typeof obj !== "object" || obj == null) {
    //obj是null,或者不是对象和数组,直接返回
    return obj;
  }
  //初始化返回结果
  let result;
  if (obj instanceof Array) {
    result = [];
  } else {
    result = {};
  }
  for (let key in obj) {
      //保证key不是原型的属性
    if (obj.hasOwnProperty(key)) {
        //递归调用
      result[key] = deepClone(obj[key]);
    }
  }
  return result;
}

4丶js中=区别
双等号==:
(1)如果两个值类型相同,再进行三个等号(===)的比较

(2)如果两个值类型不同,也有可能相等,需根据以下规则进行类型转换在比较:

1)如果一个是null,一个是undefined,那么相等

2)如果一个是字符串,一个是数值,把字符串转换成数值之后再进行比较
三等号===:

(1)如果类型不同,就一定不相等

(2)如果两个都是数值,并且是同一个值,那么相等;如果其中至少一个是NaN,那么不相等。(判断一个值是否是NaN,只能使用isNaN( ) 来判断)

(3)如果两个都是字符串,每个位置的字符都一样,那么相等,否则不相等。

(4)如果两个值都是true,或是false,那么相等

(5)如果两个值都引用同一个对象或是函数,那么相等,否则不相等

(6)如果两个值都是null,或是undefined,那么相等
5,数据类型判断
数据类型:
基本数据类型:number丶String丶Boolean丶null丶undefined丶
引用数据类型:function丶Array丶Date
一共有4种,分别是typeof丶instanceof丶constructor丶Object.prototype.toString.call()。
typeof判断基本数据类型没有什么问题,比如对象丶数组会出错。

typeof {} // object

instanceof 和 constructor 是用来判断引用数据类型,但是也会出错,instanceof 不是判断null和undefined,而constructor 不能判断出构造函数,并且把他的原型指向Array的原型,这样就会出错。

console.log(arr instanceof Array ); // true
console.log(arr.constructor === Array); //true

Object.prototype.toString.call()是判断本身是引用数据类型,比如对象丶数组。

console.log(toString.call('123')); //[object String]
当面试官询问JavaScript基础面试题时,以下是一些常见的问题和答案: 1. 什么是JavaScriptJavaScript是一种高级的、解释型的编程语言,用于在网页上实现交互和动态功能。 2. JavaScript的数据类型有哪些? JavaScript有七种数据类型:字符串(String)、数字(Number)、布尔值(Boolean)、对象(Object)、数组(Array)、空(Null)和未定义(Undefined)。 3. 如何声明变量? 使用关键字`var`、`let`或`const`来声明变量。例如: ``` var x = 5; let y = "Hello"; const z = true; ``` 4. JavaScript中的事件是什么? 事件是指用户在网页上执行的动作,如点击按钮、鼠标移动等。通过JavaScript可以捕捉并对这些事件做出响应。 5. 什么是闭包? 闭包是指函数能够访问并操作其外部函数作用域中的变量。它通过将内部函数返回或传递给其他函数来实现。 6. 什么是原型链? 原型链是JavaScript中实现继承的机制。每个对象都有一个原型对象,而原型对象又有自己的原型对象,形成一个链式结构。 7. 如何遍历数组? 可以使用循环结构(如`for`循环或`forEach`方法)来遍历数组中的每个元素。 8. 什么是AJAX? AJAX(Asynchronous JavaScript and XML)是一种用于在后台与服务器进行数据交互的技术。它可以在不刷新整个页面的情况下更新部分页面内容。 9. 如何处理异步编程? 可以使用回调函数、Promise对象或async/await来处理异步编程。这些方法可以确保在异步操作完成后执行相应的操作。 10. 什么是作用域? 作用域是指变量的可访问范围。JavaScript中有全局作用域和局部作用域(函数作用域和块级作用域)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值