2024 高频前端面试题汇总之js篇(一)

📢最近准备春招啦了,所以整理了一些前端高频大厂面试题,分享给大家,如有问题欢迎留言指正,面试专栏我会长期更新,欢迎大家点赞🤞、收藏📌,关注➕,感谢!
2024 高频前端面试题汇总之CSS篇(一)

2024 高频前端面试题汇总之CSS篇(二)
关注后续更新。。。

1. js数组上有哪些方法?

  1. Array.from() 将伪数组转换为真数组

  2. Array.of() 将一组值转换为数组

2. js字符串上有哪些方法?

  1. 添加元素:concat() 拼接

  2. 删除元素:splice() 方法和数组一样的,substring(),substr()

const str = 
console.log(str.substring(1, 3));
// Expected output: "oz"
console.log(str.substring(2));
// Expected output: "zilla"

  1. 改:replace() trimRight trimLeft trim padStart padEnd toUpperCase toLowerCase

  2. 查:indexOf includes lastIndexOf find endsWith startWith

  3. 转换: split

3. 谈谈js中的类型转换机制 

类型转换机制是一种类型转换为另一种类型,分别有隐式类型转换和显示类型转换这俩种转换。 说到类型转换我们要聊到的是有哪些数据类型
简单数据类型:Number string boolean null undefined symbol Bigint
复杂数据类型:[] {} Data Regexp(正则) map set 函数 通常开发过程中,会用到一些显示类型转换的手段来完成逻辑开发 Number() ...等一些 在V8执行过程中还存在另一种类型转换 --- 隐式类型转换

通常发生在 比较运算符 和 算术运算符

== != < > if while

4. [] == ![] 对这个理解

这个问题首先我们要理解对象数据类型转换的顺序

[] == ![] 在这里我们要看逻辑运算符的==俩的优先级谁的大 当然是!的优先级大 当[]转为简单数据类型

1.  **对`!`后面的操作数转换成布尔值**
1.  **将这个布尔值取反**

在这里我们就要用到valueof讲对象转换为布尔值时为false 则这里取反 为true所有 ![]为true
等号的左边我们就要用到数据类型转换的ToPrimitive函数 ,它有两种方法将引用数据类型转换为number 和string
[]经过ToPrimitive会被转换成字符串""。再将等号两边的字符串""和布尔值false转换成数字 0 ,得到 0 == 0 。打印得到 true。 所有总结

[] == ![] [] == !true // 将空数组这个对象类型转换成布尔值  
[] == false // ! 运算符对 true 进行取反  
'' == false // 对 [] 进行 ToPrimitive 操作,返回一个空对象  
0 == 0 // 将等号两边都转换成数字类型

5. == 和 === 的区别? 

== 存在隐式类型转换 比较最后的数值
=== 比较数值 还比较数据类型 还比较存储位置

6. 说说你对闭包的理解 

  • 是什么 当一个函数中的内部函数被拿到函数外部调用,又因为在js中内层作用域总是能访问外层作用域的,那么内部函数存在对外部函数中变量的引用,这些变量的集合称之为闭包

  • 使用场景:

  1. 创建私有变量 (全局变量不易维护)

  2. 延长变量的生命周期

  3. 实现柯里化(颗粒)

  • 缺点:会造成内存泄漏 对闭包不理解的可以看看 深入理解 JavaScript 中的调用栈、作用域链和闭包

7. 什么是柯里化?

  • 是什么 将一个接受多个参数的函数转变成多个只接受一个参数的函数

如觉得本文对你有帮助的话,欢迎点赞❤❤❤,写作不易,持续输出的背后是无数个日夜的积累,您的点赞是持续写作的动力,感谢支持
来自-扯蛋蛋,欢迎大家关注!

在线整理的确实很好,对文章进行了一个汇总整理,在线备战面试、刷题指南,拿走不谢,要学会站在别人的肩膀上提升自己点击这里-->

最后:

如果你现在正在找工作,可以私信“web”或者直接添加下方小助理进群领取前端面试小册、简历优化修改、大厂内推以及更多阿里、字节大厂面试真题合集,和p8大佬一起交流。

  • 18
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Web面试那些事儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值