javascript 面试题

本文详细探讨了JavaScript单线程中的同步与异步执行机制,重点讲解了process.nextTick和setImmediate的区别,以及promise、async/await在异步任务中的应用。同时涵盖了闭包、对象拷贝、深度拷贝和各种编程概念的实际操作示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

javascript 面试题

  1. Javascript 是单线程的,执行完当前任务才会执行下一个。
    先执行同步的任务,再执行异步的任务。
    异步任务:计时器(setTimeout,setInterval)、ajax 、读取文件
// 同步任务

// node里面的方法,在同步任务之后,异步任务之前执行
process.nextTick(()=>{
  console.log(6)
})

// 异步任务

// node里面的方法,在同步任务之后,异步任务之后执行
setImmediate(()=>{
  console.log(6)
})
  1. 宏任务和微任务>>>异步任务
    宏任务:计时器(setTimeout,setInterval)、ajax 、读取文件
    微任务:promise.then
    执行顺序:
    1.同步程序
    2.process.nextTick
    3.微任务
    4.宏任务
    5.setImmediate

  2. promise和async

let p = new Promise((resolve)=>{
 // 同步任务
  resolve("传给then里面的值")
}).then(res =>{
  // 异步的宏任务
}).catch(err =>{
  // 同步任务
})

// async 方法其实就是一个promise对象
async function fun(){
    return 1
  }
  // 等于
  function fun(){
    return new Promise((resolve)=>{
      return 1
    })
  }
  fun().then((data)=>{
    console.log(data);
 })
  1. 闭包
// 闭包:函数嵌套函数,里面的函数就是闭包
 function outerFun(){
   let a= 10;
   function innerFun(){
     console.log(a);
   }
   return innerFun;
 }
 let fun = outerFun;
 fun();

 // 作用:封装一段代码,实现模块化
 let xu =(function fun(){
   let a = 10;
   function add(){
     return a++
   }
   return {add}
 })()
 let test = xu.add()
 console.log(xu);
  1. 对象拷贝
let a = 10;
let b = a;
a = 20;
console.log(a,b);
// 输出 20,10

let a = {name:"小明"};
let b = a;
a.name = "小红"
console.log(a,b);
// 输出 "小红","小红"

// 原因是js的原始类型和引用类型
// 原始类型:数值,字符串,布尔,null,undefined
// 引用类型:对象
// 引用类型是存放在堆内存,通过栈内存引用

在这里插入图片描述
6.JSON实现深度拷贝

let stu = {
  name : "小光",
  age : 2
}
let stu1 = JSON.stringify(stu)
let stu2 = JSON.parse(stu1)
console.log(stu1);
// JSON.stringify(obj),将obj对象转为json格式
console.log(stu2);
// JSON.parse(obj),将json格式转为js对象
//stu2得到的就是stu的深度拷贝
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值