博客
关于我
只用这 6 个字符,就可以写出任意 JavaScript 代码!
阅读量:451 次
发布时间:2019-03-06

本文共 1358 字,大约阅读时间需要 4 分钟。

JavaScript 的神奇力量:用 6 个字符编写任意程序

你是否曾经在网上见过那些看起来奇怪却能正常运行的 JavaScript 代码?它们通常是由几个不同的字符写成的稀奇古怪的代码片段,虽然看起来毫无疑问却能发挥作用。例如,下面的代码片段看起来毫无意义,但它确实能正常运行:

[]()!+

这六个字符足以编写出任意 JavaScript 程序,这个技巧虽然被不少人知道,但鲜少有人了解它的工作原理。我们的目标是用这些字符来编写字符串“self”,并向 Self 语言致敬,因为 JavaScript 的灵感来源之一就是 Self。

JavaScript 的基本原理

这些字符之所以能发挥作用,主要归功于 JavaScript 的类型系统和数据类型转换机制。让我们来看这些字符的作用:

  • []:可以用来创建空数组。
  • !+:用于对数组进行操作。
  • ():用于将操作分组。

首先,空数组 [] 本身是一个真值,取非后会变成 false

![] === false

接下来,+[] 会将数组转换为字符串,然后进一步转换为数字。由于空数组的 toString() 方法返回空字符串,+[] 的结果是 0

+[] === 0

这种转换机制为我们提供了一个构建数字的方法。例如,+true 会变成 1,而 +false 会变成 0

+true === 1+false === 0

通过这种方式,我们可以生成所需的数字,然后将它们转换为字符,组合成目标字符串。

生成数字

为了生成数字,我们首先需要将数组转换为布尔值,然后再将布尔值转换为数字。例如:

+!(+[]) === 1

我们可以重复这个过程,生成多个数字:

+!(+[]) === 1+!(+[]) === 1+!(+[]) === 1+!(+[]) === 1

这样,我们就可以得到数字 123 等。

临门一脚,大功告成

现在我们来看看如何将这些数字转换为目标字符串“self”。每个字符对应一个数字位置:

  • s 对应字符位置 3
  • e 对应字符位置 4
  • l 对应字符位置 2
  • f 对应字符位置 0

我们可以通过下面的代码生成这些字符:

(![] + [])[3] === 's'(![] + [])[4] === 'e'(![] + [])[2] === 'l'(![] + [])[0] === 'f'

将这些字符组合起来,就得到了“self”。

最终代码

将以上逻辑整合起来,我们可以得到以下代码:

(![] + [])[+!+[] + !+[] + !+[]] + (![] + [])[+!+[] + !+[] + !+[] + !+[]] + (![] + [])[+!+[] + !+[]] + (![] + [])[+[]]

这段代码通过多次数组操作和转换,成功生成了字符串“self”。

总结

这六个字符的神奇力量源于 JavaScript 的类型转换机制和灵活的数据类型。通过对数组进行操作和转换,我们可以生成所需的数字,然后将它们转换为字符,组合成目标字符串。虽然看起来奇怪,但这种方法在 JavaScript 中确实有效。希望你能在此基础上发挥想象,编写出更多有趣的代码。无论是“self”还是其他字符串,这种方法都能帮你轻松实现!

转载地址:http://ewmyz.baihongyu.com/

你可能感兴趣的文章
OpenCV官方文档 理解k - means聚类
查看>>
OpenCV探索
查看>>
OpenCV环境搭建(一)
查看>>
openCV目标识别 目标跟踪 YOLO5深度学习 Python 计算机视觉 计算机毕业设计 源码下载
查看>>
opencv笔记(1):图像缩放
查看>>
opencv笔记(二十四)——得到轮廓之后找到凸包convex hull
查看>>
OpenCV计算点到直线的距离 数学法
查看>>
Opencv识别图中人脸
查看>>
OpenCV读写avi、mpeg文件
查看>>
opencv面向对象设计初探
查看>>
OpenCV(1)读写图像
查看>>
OpenCV:不规则形状区域中每种颜色的像素数?
查看>>
OpenCV:概念、历史、应用场景示例、核心模块、安装配置
查看>>
OpenDaylight融合OpenStack架构分析
查看>>
OpenERP ORM 对象方法列表
查看>>
openEuler Summit 2022 成功举行,开启全场景创新新时代
查看>>
openEuler 正式开放:推动计算多样化时代的到来
查看>>
OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_openeuler切换root用户_su:拒绝权限_passwd: 鉴定令牌操作错误---国产瀚高数据库工作笔记001
查看>>
OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_踩坑_安装以后系统无法联网_启动ens33网卡---国产瀚高数据库工作笔记002
查看>>
OpenFeign 入门与实战
查看>>