前端八股文--js系列

js系列-持续更新版

1.如何获取一个安全的undefined值

因为undefined是一个标识符,所以可以用来当作变量名,但是是非常危险的,因为会影响 undefined 的正常判断,因此可以使用void 0来实现:

javascript 复制代码
let a = void 0
console.log(a == undefined);//true

2.闭包是什么,有什么作用

闭包是在一个内层函数中可以访问外层函数的作用域。每当创建一个函数,闭包就会在函数创建时被创建出来。

作用:

  • 创建私有变量
  • 延长了变量的生命周期。

优点:能够实现封装和缓存等

缺点:消耗内存,不正当使用会造成内存溢出的问题。

闭包形成的条件:

1.参数嵌套;

2.将内部函数作为返回值使用;

3.内部函数必须使用外部变量。

3. 原型和原型链

每一个函数都有一个protoType属性,它是一个指针,指向原型对象,每一个实例对象都有一个__proto__属性,也指向原型对象,原型对象上有一个construct属性,指向protoType所在的函数.

原型链是利用一个引用类型继承另一个引用类型的属性和方法。(沿着__proto__查找属性和方法的链称为原型链。)

4. 深拷贝和浅拷贝的区别,如何实现一个深拷贝

浅拷贝和浅拷贝的区别主要在于他们如何处理数据和对象的引用,浅拷贝只复制对象的指针,多个对象共享一个对象数据,而深拷贝是创建一个全新的对象,与拷贝对象不共享数据,新对象改变数据对原对象没有影响。

实现一个深拷贝:

javascript 复制代码
function deepClone(res) {
	//判断res类型
	const newRes = res.constructor === Array ? [] : {};
	//遍历res
	for(let key in res) {
		//判断是否有值:有-->判断当前属性
		if(res.hasOwnProperty(key)){
			//key有三种情况:object,array,基本数据类型
			if(res[key] && typeOf res[key] === 'object') {
				newRes[key] = deepClone(res[key]);
			}else {
				newRes[key] = res[key];
			}
		}
	}
	return newRes;
}
相关推荐
不会写DN2 分钟前
通过白名单解决 pnpm i 报错 Ignored build scripts
javascript·面试·npm
UXbot4 分钟前
AI 原型工具零设计基础操作指南与功能解析(2026)
前端·ui·产品经理·原型模式·web app
yuzhiboyouye39 分钟前
VO一般java后端怎么转换成前端想要的数据
java·前端·状态模式
小脑斧1231 小时前
从范式重构到工程落地:OpenTiny NEXT 引领前端智能化新范式
前端·hermesagent·opentiny next
小江的记录本1 小时前
【AI大模型选型指南】《2026年5月(最新版)国内外主流AI大模型选型指南》(企业版)
前端·人工智能·后端·ai作画·aigc·ai编程·ai写作
幽络源小助理1 小时前
最新轻量美化表白墙系统源码v2.0_带后台版_附搭建教程
前端·开源·源码·php源码
qq_381338501 小时前
前端状态管理新范式:Zustand、Jotai 与 Preact Signals 深度对比
前端·arcgis
布局呆星1 小时前
Vue Router 笔记(二):正则路由、组件通信与动态路由
前端·javascript·vue.js
丑八怪大丑1 小时前
HTML&CSS
前端·css·html
团象科技1 小时前
全渠道出海布局之下,多币种云结算承担着怎样的作用
前端·人工智能