sb 讲解 (!(~+[])+{})[--[~+""][+[]]*[~+[]] + ~~!+[]]+({}+[])[[~!+[]]*~+[]]

本文详细解析了一段JavaScript代码如何通过特殊的表达式组合输出字符串'sb'。文章深入介绍了JavaScript中一元操作符和二元操作符的工作原理,并且解释了如何通过字符串拼接和索引访问来实现特定字符的输出。

代码:(!(~+[])+{})[--[~+""][+[]]*[~+[]] + ~~!+[]]+({}+[])[[~!+[]]*~+[]]

输出sb。

分段解析:

   首先解析s:

    (!(~+[])+{})  --> 输出 "false[object Object]" 

    由于 ! 优先级 高于 +, 所有先算 !(~+[]), 而 ~+[] ,根据标准。。解释器会把 [] 转成 0;从而得到 ~0. =-1,所以 (~+[])=-1,而 !(-1) =false;

    从而得到 (false+{}). 标准规定默认相加会调用toString 操作。相当于 "false"+"[object Object]"; 

    下面解析 索引位置:[--[~+""][+[]]*[~+[]] + ~~!+[]]

    首先确定运算顺序: 由于[]高于 --,-- 优先级高于 *和+。 顺序如下

       1.  [~+""] =r1 = ~(+"")   而 +"" =0; 所以 ~+"" ==>~0=-1;故为 [-1]

       2.  [ +[] ]= r2 = [0]   

       3.  [~+[]]=r3 = [~0] = [-1]

       4.  [(--r1r2)*r2+~~!+[]] =  [--[-1][0]*[-1]+1] = [--(-1)*[-1]+1] = [-2*[-1]+1]=[3]

       返回结果 [3]; 备注 : ~~!+[]  = 1

    所以(!(~+[])+{})[--[~+""][+[]]*[~+[]] + ~~!+[]]='s';

  下面看b:({}+[])[[~!+[]]*~+[]]

    首先看:({}+[]) 结果为 "[object Object]". 按标准会把两边操作数toString 操作。结果 "[object Object]"+""="[object Object]"

    然后 [[~!+[]]*~+[]]:

    1. [~!+[]]

      1.1 +[]=r1=0

      1.2  !r1=r2=!0=true   (-)一元操作符说明:

      1.3  ~r2=~true=-2

    所以 [~!+[]]=[-2]

    2.~+[]

      2.1 +[]=r1=0     (+): 一元操作符说明:http://es5.github.io/index.html#x11.4.6

      2.2 ~r1=~0=-1   ( ~ )一元操作符说明:http://es5.github.io/index.html#x11.4.8

      所以 ~+[]=-1    

    所以 [[~!+[]]*~+[]]=[-2]*[-1]=2      (*) 二元操作符说明:http://es5.github.io/index.html#x11.5.1

    所以 ({}+[])[[~!+[]]*~+[]]= "[object Object][2]"=b;

    

   

        

    

 

 

    

 

转载于:https://www.cnblogs.com/Mr-Joe/p/4239460.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值