我的编程空间,编程开发者的网络收藏夹
学习永远不晚

晕!面试题console.log(([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]])输出什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

晕!面试题console.log(([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]])输出什么

本篇文章给大家带来了关于前端的相关知识,其中主要跟大家分享一道有关console.log的面试题,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。

前言

面试题console.log(([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]])输出什么?面试遇到了这一个面试题,该面试题考察了类型转换,隐式类型转换,操作符等,我没答出来,不是我不会,是我光看题就很晕了。然而它确实是面试题,那就试着解决看看咯。

5f4abdec908895a6ec7b7c15ff07394.png

解决这个题目需要的知识

  • “+”:一元+会执行与使用Number()一样的转换
  • 如果+号是两个数相加,任一操作数是对象、数值或者布尔,则调用它们的toString方法转为字符串
  • “!”:非操作符,这个操作始终返回布尔值
  • “!!”:强制转为布尔值

解决这个题目([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]]

首先我们要先理清它的执行顺序

首先执行([][[]] + []),先执行里面的[][[]],在计算 [][[]]时,其实就是执行[]空数组里面key为[]的值

  1. 首先,JavaScript 引擎解析空数组 []。空数组没有任何元素。
  2. 接下来,引擎尝试使用 [] 作为属性名来访问空数组的属性。在这种情况下,由于 [] 本身是一个数组,JavaScript 引擎会尝试将其转换为字符串。由于 [] 为空数组,转换成字符串后结果为一个空字符串 ""
  3. 最后,引擎会尝试访问空数组中名为 "" 的属性。由于这个属性并不存在于空数组中,所以结果为 undefined

所以,执行 [][[]] 的结果是 undefined

那么([][[]] + [])接下去执行就是(undefined + []) 将会执行隐式类型转换,将undefined转换为字符串"undefined",将[]转为“”,然后将两个字符串拼接在一起。因此,结果是"undefined"

其次执行[+!![]],!![]空数组转布尔值为true,一元操作服+会转为数值,+true就是将true转换为数字1。得到的结果就是[1]。于是我们就可以得到([][[]] + [])[+!![]]undefined[1]这个的结果就是字符串'n'

接下来就是执行([]+{})[+!![]+ + !![]] 这一部分,再将这部分的结果和上面的结果相加

  1. 先执行([]+{}), 计算[]+{}。这将触发隐式类型转换,将空对象转换为字符串"[object Object]",然后将两个字符串拼接在一起。因此,结果是'[object Object]'

  2. 再执行[+!![]+ + !![]], +!![]前面有解析过得到的是1,所以这一部分执行过后得到的是数值1相加1+1,得到的结果是[2]

  3. 那么这两部分合起来就是'[object Object]'[2],就是字符串的第三个值b

最后将前面部分得到的结果 'n' 和后面部分得到的结果 'b' 相加,得到最后的结果'nb'

总结:这个题目一时解决不了的话,可能有以下几个原因,第一个就是不太清楚执行顺序,其次就是不太理解[][[]]这个,实际上就是获取空数组key为[]的值,又因为数组的key为字符串,所以会将[]转为''是找不到的所以返回undefined。现在你会这道面试题了吗?

以上就是晕!面试题console.log(([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]])输出什么的详细内容,更多请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

晕!面试题console.log(([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]])输出什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

晕!面试题console.log(([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]])输出什么

本篇文章给大家带来了关于前端的相关知识,其中主要跟大家分享一道有关console.log的面试题,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。
2023-05-14

PHP面试题console.log(([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]])输出什么

这篇“PHP面试题console.log(([][[]] + [])[+!![]]+([]+{})[+!![]+ + !![]])输出什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值
2023-07-06

Python有什么面试题

本篇内容介绍了“Python有什么面试题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、Python编程是什么?他会鼓励你与其它语言做对比
2023-06-17

python面试题之什么是lambda函

lambda表达式,通常是在需要一个函数,但是又不想费神去命名一个函数的场合下使用,也就是指匿名函数。lambda所表示的匿名函数的内容应该是很简单的,如果复杂的话,干脆就重新定义一个函数了,使用lambda就有点过于执拗了。 add =
2023-01-31

python面试题之Python支持什么

所属网站分类: 面试经典 > python作者:外星人入侵链接:http://www.pythonheidong.com/blog/article/67/来源:python黑洞网,专注python资源,python教程,python技术Py
2023-01-31

java数组中有什么面试题

这篇文章给大家分享的是有关java数组中有什么面试题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序
2023-06-14

Java的5道面试题是什么

本篇内容主要讲解“Java的5道面试题是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java的5道面试题是什么”吧!XML技术的作用?XML技术用于数据存储、信息配置、数据交换三方面。可以
2023-06-02

Go/Gin 调试输出的含义是什么 - (x handlers)

php小编柚子为您解答Go/Gin调试输出中的"(x handlers)"的含义。在Go语言的Gin框架中,"(x handlers)"代表请求经过的中间件数量。中间件是Gin框架中用于处理请求的一种机制,可以在请求到达路由处理函数之前或之
Go/Gin 调试输出的含义是什么 - (x handlers)
2024-02-09

qt在界面输出文字的方法是什么

Qt中输出文字的方法有多种,具体取决于你想要在哪个界面上输出文字。如果你想要在一个文本框(QTextEdit)中输出文字,你可以使用setText()方法或者append()方法来设置文本框的内容。例如:```cppQTextEdit *t
2023-08-09

python面试题之什么是PEP8规范

1 缩进。4个空格的缩进(编辑器都可以完成此功能),不使用Tap,更不能混合使用Tap和空格。2 每行最大长度79,换行可以使用反斜杠,最好使用圆括号。换行点要在操作符的后边敲回车。3 类和top-level函数定义之间空两行;类中的方法定
2023-01-31

JAVA十大面试问答题是什么

本篇内容介绍了“JAVA十大面试问答题是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  1、String是最基本的数据类型吗?  答:
2023-06-27

面试前必须要知道的21道Redis面试题是什么

本篇内容介绍了“面试前必须要知道的21道Redis面试题是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、使用redis有哪些好处?速
2023-06-04

常用16个c/c++面试题是什么

本篇内容主要讲解“常用16个c/c++面试题是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“常用16个c/c++面试题是什么”吧!1. C中static有什么作用(1)隐藏。 当我们同时编译
2023-06-26

Java常见的10道面试题是什么

这篇文章主要讲解了“Java常见的10道面试题是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java常见的10道面试题是什么”吧!1.什么是并发修改异常?什么是并发修改异常:当我们在遍
2023-06-02

编程热搜

目录