1. <tfoot id='8PWHB'></tfoot>

        <legend id='8PWHB'><style id='8PWHB'><dir id='8PWHB'><q id='8PWHB'></q></dir></style></legend>
          <bdo id='8PWHB'></bdo><ul id='8PWHB'></ul>

        <small id='8PWHB'></small><noframes id='8PWHB'>

        <i id='8PWHB'><tr id='8PWHB'><dt id='8PWHB'><q id='8PWHB'><span id='8PWHB'><b id='8PWHB'><form id='8PWHB'><ins id='8PWHB'></ins><ul id='8PWHB'></ul><sub id='8PWHB'></sub></form><legend id='8PWHB'></legend><bdo id='8PWHB'><pre id='8PWHB'><center id='8PWHB'></center></pre></bdo></b><th id='8PWHB'></th></span></q></dt></tr></i><div id='8PWHB'><tfoot id='8PWHB'></tfoot><dl id='8PWHB'><fieldset id='8PWHB'></fieldset></dl></div>

      1. JavaScript - 防止八进制转换

        JavaScript - Preventing octal conversion(JavaScript - 防止八进制转换)
      2. <legend id='vDQwT'><style id='vDQwT'><dir id='vDQwT'><q id='vDQwT'></q></dir></style></legend>
        • <bdo id='vDQwT'></bdo><ul id='vDQwT'></ul>

          <i id='vDQwT'><tr id='vDQwT'><dt id='vDQwT'><q id='vDQwT'><span id='vDQwT'><b id='vDQwT'><form id='vDQwT'><ins id='vDQwT'></ins><ul id='vDQwT'></ul><sub id='vDQwT'></sub></form><legend id='vDQwT'></legend><bdo id='vDQwT'><pre id='vDQwT'><center id='vDQwT'></center></pre></bdo></b><th id='vDQwT'></th></span></q></dt></tr></i><div id='vDQwT'><tfoot id='vDQwT'></tfoot><dl id='vDQwT'><fieldset id='vDQwT'></fieldset></dl></div>

            <tfoot id='vDQwT'></tfoot>
              <tbody id='vDQwT'></tbody>

              <small id='vDQwT'></small><noframes id='vDQwT'>

                  本文介绍了JavaScript - 防止八进制转换的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我将数字输入作为参数,只是试图解释前导零.但似乎 javascript 在我可以对数字做任何事情之前将数字转换为八进制.到目前为止,解决它的唯一方法是,如果我最初将数字作为字符串传递,但我希望在传递后有另一种方法来转换它?到目前为止尝试过(使用 017 提醒我注意八进制行为):

                  I'm taking a numerical input as an argument and was just trying to account for leading zeroes. But it seems javascript converts the number into octal before I can do anything to the number. The only way to work around it so far is if I pass the number as a string initially but I was hoping there'd be another way to convert it after it is passed? So far tried (using 017 which alerted me to the octal behaviour):

                  017.toString(10) // 15
                  parseInt(017,10) // 15
                  017 + "" //15
                  new Number(017) //15
                  
                  new Number('017') //17
                  parseInt('017', 10) // 17
                  

                  给定

                  function(numb) {
                  
                  if (typeof numb === number) {
                  // remove leading zeroes and convert to decimal
                  }
                  else {
                   // use parseInt
                  }
                  
                  }
                  

                  'use strict' 似乎也没有像一些较早的帖子所建议的那样解决这个问题.有什么想法吗?

                  'use strict' also doesn't seem to solve this as some older posts have suggested. Any ideas?

                  推荐答案

                  1. 如果你采用数字输入",你应该始终保证有一个字符串.在这种情况下,我知道没有返回 Number 的输入法.由于您收到一个字符串,因此 parseInt(.., 10) 将始终足够.017 只有在源代码中按字面意思写成八进制时才被解释为八进制(或者当缺少 parseInt 的 radix 参数时).
                  2. 如果出于某种奇怪的原因,您最终将十进制解释为八进制,并且您想将该值反向转换回十进制,这很简单:用八进制表示该值并将其重新解释为十进制:

                  1. If you take "numerical input", you should always definitely guaranteed have a string. There's no input method in this context that I know that returns a Number. Since you receive a string, parseInt(.., 10) will always be sufficient. 017 is only interpreted as octal if written literally as such in source code (or when missing the radix parameter to parseInt).
                  2. If for whatever bizarre reason you do end up with a decimal interpreted as octal and you want to reverse-convert the value back to a decimal, it's pretty simple: express the value in octal and re-interpret that as decimal:

                  var oct = 017; // 15
                  parseInt(oct.toString(8), 10) // 17
                  

                  虽然您可能不知道输入最初是否被解释为八进制,但这不是您应该做的事情.

                  Though because you probably won't know whether the input was or wasn't interpreted as octal originally, this isn't something you should have to do ever.

                  这篇关于JavaScript - 防止八进制转换的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  What are valid deviceNames for Chrome emulation testing with Protractor?(使用 Protractor 进行 Chrome 模拟测试的有效设备名称是什么?)
                  Protractor Check if Element Does Not Exist(量角器检查元素是否不存在)
                  Protractor e2e Tests Login Redirection(Protractor e2e 测试登录重定向)
                  Explain about async/ await in Protractor(解释 Protractor 中的 async/await)
                  Protractor browser.wait doesn#39;t wait(量角器 browser.wait 不等待)
                  How to use Protractor with Angular 2?(如何在 Angular 2 中使用量角器?)

                  • <bdo id='Ks5Ly'></bdo><ul id='Ks5Ly'></ul>

                      <i id='Ks5Ly'><tr id='Ks5Ly'><dt id='Ks5Ly'><q id='Ks5Ly'><span id='Ks5Ly'><b id='Ks5Ly'><form id='Ks5Ly'><ins id='Ks5Ly'></ins><ul id='Ks5Ly'></ul><sub id='Ks5Ly'></sub></form><legend id='Ks5Ly'></legend><bdo id='Ks5Ly'><pre id='Ks5Ly'><center id='Ks5Ly'></center></pre></bdo></b><th id='Ks5Ly'></th></span></q></dt></tr></i><div id='Ks5Ly'><tfoot id='Ks5Ly'></tfoot><dl id='Ks5Ly'><fieldset id='Ks5Ly'></fieldset></dl></div>
                      <tfoot id='Ks5Ly'></tfoot>
                        <tbody id='Ks5Ly'></tbody>

                            <small id='Ks5Ly'></small><noframes id='Ks5Ly'>

                            <legend id='Ks5Ly'><style id='Ks5Ly'><dir id='Ks5Ly'><q id='Ks5Ly'></q></dir></style></legend>