search

Home  >  Q&A  >  body text

javascript - 关于 -[1,] 的疑问

发现js中
-[1,] 的返回值为 -1
以此类推, -[2,]或者+[2,],返回值为 -22
但是如果是 +[1,2] 或者是 -[1,2],则返回值为 NaN
请各位大神解释下这其中的原理

PHP中文网PHP中文网2846 days ago472

reply all(2)I'll reply

  • PHP中文网

    PHP中文网2017-04-10 15:36:37

    这里面涉及两个问题:一是 JavaScript 数组中 trailing comma 的处理,二是 JavaScript 中数组的类型转换。

    关于 trailing comma:

    ES5 忽略 trailing comma,认为 [1,] 与 [1] 一样,都表示一个有单一元素的数组(但只实现了 ES3 的JS引擎可能不这么认为)。

    // 现代浏览器或 Node.js 环境
    [1,].length  // => 1
    [1].length  // => 1
    

    ES5 Spec:

    11.1.4: Edition 5 clarifies the fact that a trailing comma at the end of an ArrayInitialiser does not add to the length of the array. This is not a semantic change from Edition 3 but some implementations may have previously misinterpreted this.

    所以,在实现了 ES5 的 JS 引擎里,[1,] 实际上就是 [1]。

    关于数组的类型转换:

    基本步骤:
    调用内部 toPrimitive 方法 ----> 调用 [[DefaultValue]]方法(以 Number 作为 hint) ----> 调用数组的 valueOf() 方法,然而并未得到原始值 ----> 调用数组的 toString() 方法,得到 String 类型值 ----> 用一元取反运算符(-)或运算符(+)处理,得到 Number 类型值。

    -[1] 的处理过程:

    -[1]    ------>         -'1'       ---------> -1 
    

    -[1, 2] 的处理过程:

    -[1, 2]    ------>         -'1,2'       ---------> -NaN 
    

    -[] 的处理过程:

    -[]        -------->       -''          ---------> -0
    

    这是一个看标准就能解决的问题,不过在生产环境中,不要在数组中使用 trailing comma。

    reply
    0
  • 阿神

    阿神2017-04-10 15:36:37

    我也是看了你的问题,才去查资料。

    首先,为什么[1,]返回1呢?其实不然的,这个要区分IE(IE10是否修复未知)和非IE浏览器,IE浏览器返回的是"1,",而非IE返回"1"。[]本来是数组标记,但是当我们把它用在+-操作中,实际上[1,]首先会被执行.toString(),非IE浏览器中,"1,"末尾的","会被省略,省略后又可以作为数值进行运算。所以,在你的题目中,-[1,]返回-1,仅在非IE浏览器中是正确的,而IE浏览器中执行的则是-"1,",即字符串进行运算,返回的是NaN。同样的道理[2,]的结果仍然也区分IE与非IE。

    其次,+[1,2]为什么在两种浏览器中都是NaN呢?因为在IE中不管是[1,]还是[1,2],其结果都是带","的字符串,但是在非IE浏览器中,[1,]结果是1,可以作为数值进行运算,而[1,2]结果是"1,2",是字符串。

    其实,我也是一知半解,胡乱说的~

    reply
    0
  • Cancelreply