Why are Octal numeric literals not allowed in strict mode (and what is the workaround?)

前端 未结 4 502
攒了一身酷
攒了一身酷 2020-12-03 17:23

Why are Octal numeric literals not allowed in JavaScript strict mode? What is the harm?

相关标签:
4条回答
  • 2020-12-03 17:41

    The "why" part of the question is not really answerable.

    As for "how", off the top of my head...

    "use strict";
    var x = parseInt('010', 8);
    document.write(x);

    0 讨论(0)
  • 2020-12-03 17:42

    Octal literals are not allowed because disallowing them discourages programmers from using leading zeros as padding in a script. For example, look at the following snippet:

    var eight = 0008,
        nine = 00009,
        ten = 000010,
        eleven = 011;
    
    console.log(eight, nine, ten, eleven);

    Seems harmless enough, right? We programmers with OCD just want to align all the commas together so it looks nicer. But here's the problem:

    8 9 8 9
    

    This is the output. See how inconsistent it becomes? Not all zero-padded numeric literals will convert to octal, since 8 and 9 are not octal digits. It's harder to keep them consistent when having to remember all these rules, so strict mode makes it easier by disallowing it altogether.

    Instead you should pad with leading spaces, or if you want to use octal, then utilize parseInt() with the optional radix argument of 8 to specify octal.

    Here are the two "solutions", respectively:

    "use strict";
    
    var eight  =  8,
        nine   =  9,
        ten    = 10,
        eleven = 11;
    
    console.log(eight, nine, ten, eleven);

    "use strict";
    
    var eight  = parseInt('010', 8),
        nine   = parseInt('011', 8),
        ten    = parseInt('012', 8),
        eleven = parseInt('013', 8);
    
    console.log(eight, nine, ten, eleven);

    0 讨论(0)
  • 2020-12-03 17:48

    Why is Octal numeric literals not allowed in javascript strict mode? What is the harm?

    Octals in JS have historically been a non-standard extension to the standard (in ES5, which introduces strict mode, they're in Annex B, which is a collection of non-standard features that most implementations support: except it defines octals in a way incompatible with what websites require), and strict mode made an attempt to disallow all non-standard extensions. The "why" as to why they were never standardised is an obvious related question, and that I'm unaware of.

    In case a developer need to use Octals (which can mistakenly change a number's meaning), is there a work around?

    As @Amit answered, parseInt with its second argument as 8 still works in strict mode.

    0 讨论(0)
  • 2020-12-03 18:06

    Nowadays, with large browser support to ES6, you could write this:

    const NINE = 0o11; // octal
    const TEN = 0b1010; // binary
    const SEVENTEEN = 0x11; // hexa
    
    0 讨论(0)
提交回复
热议问题