当前位置: 首页 > news >正文

前端面经每日一题day06

Cookie有什么字段

Name:cookie的唯一标识符

Value:与Name对应,存储Cookie的信息

Domain:可以访问cookie的域名

Path:可以访问cookie的路径

Expires/Max-Age:超时时间

Size:cookie大小

HttpOnly:cookie只能通过HTTP发送

Secure:cookie只能通过HTTPS发送

SameSite:控制跨站点请求是否发送cookie。Strict(同站)Lax(某些跨站可以)None(都可以)

如何实现一个深拷贝 (cloneDeep)

首先我们要了解,深拷贝和浅拷贝是复制对象的两种方式。

浅拷贝:创建一个新对象,新对象是原始对象的引用。如果修改了原来对象里面某个对象属性,新对象也会被修改。

深拷贝:创建一个完全独立于原始对象的副本。

如何实现

//浅拷贝的实现 这里都是修改深层次的才会都被修改
//对象  Object.assign({},obj)
let obj={a:'123',b:{c:'333'}}
let shaowcopy=Object.assign({},obj)
obj.a='6666'
obj.b.c='999'
console.log(obj,shaowcopy) //showcopy {a: '123', b: {c: '999'}}
// 数组 Array.prototype.slice.call(a)
let a=[1,2,3,4,{a:'111'}]
let shaowa=Array.prototype.slice.call(a)
a[1]='0000'
a[4].a='0000'
console.log(a,shaowa) //[1, 2, 3, 4, {a: '000'}]
//深拷贝的实现 
//数组和对象都可以 JSON.parse(JSON.stringify(obj))
let obj={a:'123',b:{c:'333'}}
let shaowcopy=JSON.parse(JSON.stringify(obj))
obj.a='6666'
obj.b.c='999'
console.log(obj,shaowcopy)

请简述一下 event loop

答:JS是单线程的,所有任务都需要排队,前一个任务结束才会执行后一个任务。为了解决排出等待问题,JS的任务分为同步任务和异步任务。所有同步任务在主线程上执行,形成stack。异步任务不进入主线程,进入队列。同步任务顺序执行,只有执行栈stack中的同步任务都执行完成了,系统才会把任务队列的异步任务,放入执行栈中执行,如此循环,直到所有任务执行完毕。

  • 同步任务:注意一个new Promise((resolve,reject)⇒{console.log(’a’) resolve()).then() Promise里面是同步任务,then里面的是异步任务。
  • 异步任务分为宏任务和微任务。
    宏任务:setTimeoutsetInterval、放到队尾
    微任务:Promise.thenprocess.nextTick 放到队首
    异步任务里面,微任务全部执行完,才会执行宏任务。

下图所示是JavaScript执行任务的图解以及文字描述。

heap(堆):对象被分配在堆里面,堆一个用来表示一大块内存区域。
stack(栈):函数调用形成了一个由若干帧组成的栈。
webAPIS:包括DOM和相关的API
队列(event queue||callback queue):放置异步函数

//下面是一个例子
process.nextTick(function() {console.log('6');
})
new Promise(function(resolve) {console.log('7');resolve();
}).then(function() {console.log('8')
})
setTimeout(function() {console.log('9');process.nextTick(function() {console.log('10');})new Promise(function(resolve) {console.log('11');resolve();}).then(function() {console.log('12')})
})
//整段代码,共进行了三次事件循环,完整的输出为1,7,6,8,2,4,3,5,9,11,10,12。console.log('start')
setTimeout(() => {console.log('setTimeout')
}, 0)
new Promise((resolve) => {console.log('promise')resolve()
}).then(() => {console.log('then1')
}).then(() => {console.log('then2')
})
console.log('end')    
//start,promise,end,then1,then2,setTimeout

http://www.lryc.cn/news/500038.html

相关文章:

  • SOC,SOH含义区别及计算公式
  • 阿里云轻量应用服务器开放端口,图文教程分享
  • 嵌入式里的“移植”概念
  • 深入探讨 AF_PACKET 套接字
  • Redis的哨兵机制
  • CSS系列(1)-- 选择器体系详解
  • 用Python开发打字速度测试小游戏
  • 基于gitlab API刷新MR的commit的指定status
  • 服务器数据恢复—LINUX下各文件系统删除/格式化的数据恢复可行性分析
  • Spark on Yarn安装配置,大数据技能竞赛(容器环境)
  • 遣其欲,而心自静 -- 33DAI
  • No.25 笔记 | 信息收集与Google语法的实践应用
  • GitLab基础环境部署:Ubuntu 22.04.5系统在线安装GitLab 17.5.2实操手册
  • SpringBoot3配置文件
  • 【机器学习】任务十二:循环神经网络
  • 【返璞归真】-切比雪夫不等式(Chebyshev‘s Inequality)
  • 【Django】在view中调用channel来主动进行websocket通信
  • 18.[极客大挑战 2019]BabySQL1
  • Python快速入门二:Python3 基础语法
  • 1-1 C语言链表
  • [0629].第29节:配置中心业务规则与动态刷新
  • mac: docker : Command not found解决
  • Django drf基于APIView 快速使用
  • 【MarsCode】每日一题数组 之 数字分组求偶数和
  • 解决:error: subprocess-exited-with-error 的问题
  • 使用腾讯混元(HunYuanVideo)视频模型FP8量化版本来生成绅士动画,模型体积30G,8G甜品卡可玩,2秒视频需要15分钟
  • 使用Ancona安装node,安装vue
  • 如何“安装Android SDK“?
  • 天童教育:提升孩子的语言表达能力
  • Node.js中JWT的token完整生命周期管理:从生成到销毁