aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/javascript/reference/global_objects/parseint/index.html
blob: 4f2def476acba908020986f47cacdd02da3743f2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
---
title: parseInt
slug: Web/JavaScript/Reference/Global_Objects/parseInt
tags:
  - JavaScript
  - parseInt()
translation_of: Web/JavaScript/Reference/Global_Objects/parseInt
---
<div>
<div>
<div>{{jsSidebar("Objects")}}</div>
</div>
</div>

<p><strong>parseInt(<em>string</em>, <em>radix</em></strong> 解析一个字符串并返回指定基数的十进制整数, <code>radix</code> 是2-36之间的整数,表示被解析字符串的基数。</p>

<p>{{EmbedInteractiveExample("pages/js/globalprops-parseint.html")}}</p>

<h2 id="语法">语法</h2>

<pre class="syntaxbox">parseInt(<em>string</em>, <em>radix</em>);</pre>

<h3 id="参数">参数</h3>

<dl>
 <dt><code>string</code></dt>
 <dd>要被解析的值。如果参数不是一个字符串,则将其转换为字符串(使用  <code><a href="http://www.ecma-international.org/ecma-262/6.0/#sec-tostring">ToString</a> </code>抽象操作)。字符串开头的空白符将会被忽略。</dd>
</dl>

<dl>
 <dt><code><var>radix</var></code><var> {{optional_inline}}</var></dt>
 <dd><code>2</code><code>36</code>,表示字符串的基数。例如指定 <code>16</code> 表示被解析值是十六进制数。请注意,10不是默认值!</dd>
 <dd class="blockIndicator warning">文章后面的<a href="#描述">描述</a>解释了当参数 <code>radix</code> 不传时该函数的具体行为。</dd>
</dl>

<h3 id="返回值">返回值</h3>

<p>从给定的字符串中解析出的一个整数。</p>

<p>或者 {{jsxref("NaN")}},当</p>

<ul>
 <li><code>radix</code> 小于 <code>2</code> 或大于 <code>36</code> ,或</li>
 <li>第一个非空格字符不能转换为数字。</li>
</ul>

<pre>parseInt('123', 5) // 将'123'看作5进制数,返回十进制数38 =&gt; 1*5^2 + 2*5^1 + 3*5^0 = 38</pre>

<h2 id="描述_2"><a name="描述">描述</a></h2>

<p><code>parseInt</code>函数将其第一个参数转换为一个字符串,对该字符串进行解析,然后返回一个整数或 <code>NaN</code></p>

<p>如果不是<code>NaN</code>,返回值将是以第一个参数作为指定基数 radix 的转换后的十进制整数。(例如,<code>radix</code><code>10</code>,就是可以转换十进制数,为<code>8</code>可以转换八进制数"07",<code>16</code>可以转换十六进制数"0xff",以此类推)。</p>

<p>对于 <code>radix </code><code>10</code>以上的,英文字母表示大于<code>9</code>的数字。例如,对于十六进制数(基数<code>16</code>),则使用 <code>A</code><code>F</code></p>

<p>如果 <code>parseInt </code>遇到的字符不是指定 <code>radix </code>参数中的数字,它将忽略该字符以及所有后续字符,并返回到该点为止已解析的整数值。 <code>parseInt</code> 将数字截断为整数值。 允许前导和尾随空格。</p>

<p>由于某些数字在其字符串表示形式中使用e字符(例如 <code>6.022×23</code> 表示<code> 6.022e23</code> ),因此当对非常大或非常小的数字使用数字时,使用 <code>parseInt</code> 截断数字将产生意外结果。 <code>parseInt</code>不应替代{{jsxref("Math.floor()")}}</p>

<p><br>
 <code>parseInt</code> 可以理解两个符号。<code>+</code> 表示正数,<code>-</code> 表示负数(从ECMAScript 1开始)。它是在去掉空格后作为解析的初始步骤进行的。如果没有找到符号,算法将进入下一步;否则,它将删除符号,并对字符串的其余部分进行数字解析。</p>

<p>如果 <code>radix</code> 是 <code>undefined</code><code>0</code>或未指定的,JavaScript会假定以下情况:</p>

<ol>
 <li>如果输入的 <code>string</code>以 "<code>0x</code>"或 "<code>0x</code>"(一个0,后面是小写或大写的X)开头,那么radix被假定为16,字符串的其余部分被当做十六进制数去解析。</li>
 <li>如果输入的 <code>string</code>以 "<code>0</code>"(0)开头, <code>radix</code>被假定为<code>8</code>(八进制)或<code>10</code>(十进制)。具体选择哪一个radix取决于实现。ECMAScript 5 澄清了应该使用 10 (十进制),但不是所有的浏览器都支持。<strong>因此,在使用 <code>parseInt</code> 时,一定要指定一个 radix</strong></li>
 <li>如果输入的 <code>string</code> 以任何其他值开头, <code>radix</code><code>10</code> (十进制)。</li>
</ol>

<p>如果第一个字符不能转换为数字,<code>parseInt</code>会返回 <code>NaN</code></p>

<p>为了算术的目的,<code>NaN</code> 值不能作为任何 <code>radix</code> 的数字。你可以调用{{jsxref("isNaN")}}函数来确定<code>parseInt</code>的结果是否为 <code>NaN</code>。如果将NaN传递给算术运算,则运算结果也将是 <code>NaN</code></p>

<p>要将一个数字转换为特定的 <code>radix</code> 中的字符串字段,请使用 <code>thatNumber.toString(radix)</code>函数。</p>

<div class="blockIndicator warning">
<p>{{jsxref("BigInt")}}。警告: <code>parseInt</code>{{jsxref("BigInt")}}转换为{{jsxref("Number")}},并在这个过程中失去了精度。这是因为拖尾的非数字值,包括 "n",会被丢弃。</p>
</div>

<h2 id="示例">示例</h2>

<h3 id="例子:使用_parseInt">例子:使用 <code>parseInt</code></h3>

<p>以下例子均返回<code>15</code>:</p>

<pre class="brush: js">parseInt("0xF", 16);
parseInt("F", 16);
parseInt("17", 8);
parseInt(021, 8);
parseInt("015", 10);   // parseInt(015, 8); 返回 13
parseInt(15.99, 10);
parseInt("15,123", 10);
parseInt("FXX123", 16);
parseInt("1111", 2);
parseInt("15 * 3", 10);
parseInt("15e2", 10);
parseInt("15px", 10);
parseInt("12", 13);</pre>

<p>以下例子均返回 <code>NaN</code>:</p>

<pre class="brush: js">parseInt("Hello", 8); // 根本就不是数值
parseInt("546", 2);   // 除了“0、1”外,其它数字都不是有效二进制数字
</pre>

<p>以下例子均返回 <code>-15</code></p>

<pre class="brush: js">parseInt("-F", 16);
parseInt("-0F", 16);
parseInt("-0XF", 16);
parseInt(-15.1, 10);
parseInt(" -17", 8);
parseInt(" -15", 10);
parseInt("-1111", 2);
parseInt("-15e1", 10);
parseInt("-12", 13);
</pre>

<p>下例中全部返回 <code>4</code>:</p>

<pre class="brush: js">parseInt(4.7, 10);
parseInt(4.7 * 1e22, 10); // 非常大的数值变成 4
parseInt(0.00000000000434, 10); // 非常小的数值变成 4</pre>

<p>下面的例子返回 <code>224</code></p>

<pre class="brush: js">parseInt("0e0",16);</pre>

<h2 id="没有指定_radix_参数时的八进制解析" style="margin-bottom: 20px; line-height: 30px;">没有指定 <code>radix</code> 参数时的八进制解析</h2>

<p>尽管 ECMAScript 3 已经不赞成这种做法,且 ECMAScript 5 已经禁止了这种做法,但是仍然有很多实现环境仍然把以 0 开头的数值字符串(numeric string)解释为一个八进制数。下面的例子可能返回八进制的结果,也可能返回十进制的结果。<strong>总是指定一个基数(radix)可以避免这种不可靠的行为。</strong></p>

<pre class="brush: js">parseInt("0e0");
// 0

parseInt("08");
// 0, '8' 不是八进制数字.
</pre>

<h3 id="ECMAScript_5_移除了八进制解析" style="line-height: 24px;">ECMAScript 5 移除了八进制解析</h3>

<p>ECMAScript 5 规范不再允许<code>parseInt</code>函数的实现环境把以<code>0</code>字符开始的字符串作为八进制数值。ECMAScript 5 陈述如下:</p>

<p>根据给定radix,<code>parseInt</code>函数产生一个由字符串参数内容解析过来的整数值。字符串中开头的空白会被忽略。如果radix没有指定或者为0,参数会被假定以10为基数来解析,如果数值以字符对0x或0X开头,会假定以16为基数来解析。</p>

<p>这与ECMAScript 3有所不同,ECMAScript 3仅仅是不提倡这种做法但并没有禁止这种做法。</p>

<p>直至2013年,很多实现环境并没有采取新的规范所规定的做法, 而且由于必须兼容旧版的浏览器,所以<strong>永远都要明确给出radix参数的值.</strong></p>

<h2 id="一个更严格的解析函数" style="margin-bottom: 20px; line-height: 30px;">一个更严格的解析函数</h2>

<p>有时采用一个更严格的方法来解析整型值很有用。此时可以使用正则表达式:</p>

<pre class="brush: js">filterInt = function (value) {
  if(/^(\-|\+)?([0-9]+|Infinity)$/.test(value))
    return Number(value);
  return NaN;
}

console.log(filterInt('421'));               // 421
console.log(filterInt('-421'));              // -421
console.log(filterInt('+421'));              // 421
console.log(filterInt('Infinity'));          // Infinity
console.log(filterInt('421e+0'));            // NaN
console.log(filterInt('421hop'));            // NaN
console.log(filterInt('hop1.61803398875'));  // NaN
console.log(filterInt('1.61803398875'));     // NaN
</pre>

<h2 id="规范">规范</h2>

<table class="standard-table">
 <tbody>
  <tr>
   <th>规范版本</th>
   <th>规范状态</th>
   <th>注解</th>
  </tr>
  <tr>
   <td>{{SpecName('ES1')}}</td>
   <td>{{Spec2('ES1')}}</td>
   <td>Initial definition.</td>
  </tr>
  <tr>
   <td>{{SpecName('ES5.1', '#sec-15.1.2.2', 'parseInt')}}</td>
   <td>{{Spec2('ES5.1')}}</td>
   <td></td>
  </tr>
  <tr>
   <td>{{SpecName('ES6', '#sec-parseint-string-radix', 'parseInt')}}</td>
   <td>{{Spec2('ES6')}}</td>
   <td></td>
  </tr>
  <tr>
   <td>{{SpecName('ESDraft', '#sec-parseint-string-radix', 'parseInt')}}</td>
   <td>{{Spec2('ESDraft')}}</td>
   <td></td>
  </tr>
 </tbody>
</table>

<h2 id="浏览器兼容性">浏览器兼容性</h2>

<p>{{Compat("javascript.builtins.parseInt")}}</p>

<div></div>

<h2 id="相关链接">相关链接</h2>

<ul>
 <li>{{jsxref("Global_Objects/parseFloat", "parseFloat()")}}</li>
 <li>{{jsxref("Number.parseFloat()")}}</li>
 <li>{{jsxref("Number.parseInt()")}}</li>
 <li>{{jsxref("Global_Objects/isNaN", "isNaN()")}}</li>
 <li>{{jsxref("Number.toString()")}}</li>
 <li>{{jsxref("Object.valueOf")}}</li>
</ul>