Number conversions using parseInt() and toString() in JavaScript

Anyone who codes in JavaScript regularly has made use of parseInt() to convert an integer that's expressed as a string into an actual number type that one can use in calculations.

The MDN defines the use of parseInt() as follows:

复制代码
parseInt(string)
parseInt(string, radix)

string is the value to parse. In the case that it's not a string type, it is internally converted to a string before the parsing occurs.

radix is a value between 2 and 36 which is the base of the string parameter value. It does NOT default to base 10 if this parameter is omitted. For example, a string with the prefix "0x" will default to base 16, hexadecimal. To learn in greater detail how various inputs are treated, please refer to the MDN article on parseInt() for more details.

parseInt()

parseInt() can be used to convert numbers to and from various bases if one understands how the radix parameter functions.

For example:

复制代码
parseInt("23", 4)
parseInt("0x23")
parseInt("23", 2)

will output:

复制代码
11
35
NaN

In each case we are answering the question: "What is the base 10 value of 23 in base 4? in base 16? in base 2?"

  1. "23" in base 4 is 2 * 4 + 3, or 11 in base 10.
  2. "0x23" implies base 16. 2 * 16 + 3, or 35 in base 10
  3. "23" in base 2 is NaN, since base 2 digits can only include 0 and 1.

Imagine how useful this could be if someone needs you to quickly interpret binary "1110010"!

复制代码
parseInt("1110010", 2)

will give us the correct base 10 number:

复制代码
114

toString(radix)

Using toString(radix) with a number object overrides the the Object object method toString(). When used with number objects, toString(radix) returns a string representation of the number object in the specified base.

toString(radix) answers the question: "How do I write the value 23 in base 4? in base 16? in base 2?"

复制代码
let num = 23

num.toString(4)
num.toString(16)
num.toString(2)

And the output:

复制代码
113
17
10111

In effect, parseInt() and toString() act as inverses of each other:

复制代码
let num = 23

parseInt(num.toString(4), 4)
parseInt(num.toString(16), 16)
parseInt(num.toString(2), 2)

And the result:

复制代码
23
23
23

toString(2) is particularly useful if you need to generate the binary representation of a number for any reason. Or how about converting a hexadecimal number (base 16) into its binary equivalent?

复制代码
parseInt("1F4", 16).toString(2)

"111110100"

(in case you were wondering, this is 500 in base 10!)

I hope this brief exploration of these two related methods leaves you with a greater understanding of how they go beyond converting integers to strings and vice versa. They can be used to translate numbers to and from other bases, as well!

At last ,If you want to protects your javascript code from being illegally analyzed, hacked, and stolen.You can obfuscate js with js-obfuscator or jshaman etc.

Happy Coding!

相关推荐
代码中介商6 小时前
C++左值与右值:核心判断法则详解
开发语言·c++
JAVA9656 小时前
JAVA面试-并发篇 05-并发包AQS队列实现原理是什么
java·开发语言·面试
Halo_tjn7 小时前
反射与设计模式1
java·开发语言·算法
珊瑚里的鱼7 小时前
手撕单例模式中的饿汉模式和懒汉模式,懒汉模式还要再多加一个C++11版本的
开发语言·c++·单例模式
_不会dp不改名_8 小时前
python-opencv环境搭建
开发语言·python·opencv
HappyAcmen8 小时前
9.复盘API全套流程
开发语言·python
charlie1145141918 小时前
通用GUI编程技术——图形渲染实战(四十五)——D3D12资源与堆管理:从上传到驻留
开发语言·3d·图形渲染·win32
不会C语言的男孩8 小时前
C++ Primer 第12章:动态内存
开发语言·c++
LIUAWEIO8 小时前
vue里面下载配置使用zepto vue中怎样使用zepto
javascript·vue.js·es6·zepto
lantian8 小时前
TypeScript 三斜线指令完全指南:从入门到理解为什么不再需要它
前端·javascript·vue.js