blob: ebb9e724e968d7c43d1fa7f875f0c7143e6b466b (
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
|
---
title: Symbol.for()
slug: Web/JavaScript/Reference/Global_Objects/Symbol/for
tags:
- JavaScript
- Method
- Symbol
translation_of: Web/JavaScript/Reference/Global_Objects/Symbol/for
---
<div>{{JSRef}} </div>
<p><code><strong>Symbol.for(key)</strong></code> 方法会根据给定的键 <code>key</code>,来从运行时的 symbol 注册表中找到对应的 symbol,如果找到了,则返回它,否则,新建一个与该键关联的 symbol,并放入全局 symbol 注册表中。</p>
<h2 id="Syntax">语法</h2>
<pre class="syntaxbox"><var>Symbol.for(key)</var>;</pre>
<h3 id="参数">参数</h3>
<dl>
<dt>key</dt>
<dd>一个字符串,作为 symbol 注册表中与某 symbol 关联的键(同时也会作为该 symbol 的描述)。</dd>
</dl>
<h3 id="返回值">返回值</h3>
<p>返回由给定的 key 找到的 symbol,否则就是返回新创建的 symbol。</p>
<h2 id="Description">描述</h2>
<p>和 <code>Symbol()</code> 不同的是,用 <code>Symbol.for()</code> 方法创建的的 symbol 会被放入一个全局 symbol 注册表中。<code>Symbol.for() 并不是每次都会创建一个新的 symbol</code>,它会首先检查给定的 key 是否已经在注册表中了。假如是,则会直接返回上次存储的那个。否则,它会再新建一个。</p>
<h3 id="全局_symbol_注册表">全局 symbol 注册表</h3>
<p>symbol 注册表中的记录结构:</p>
<table class="standard-table">
<caption>全局 symbol 注册表中的一个记录</caption>
<tbody>
<tr>
<th>字段名</th>
<th>字段值</th>
</tr>
<tr>
<td>[[key]]</td>
<td>一个字符串,用来标识每个 symbol</td>
</tr>
<tr>
<td>[[symbol]]</td>
<td>存储的 symbol 值</td>
</tr>
</tbody>
</table>
<h2 id="示例">示例</h2>
<pre class="brush: js">Symbol.for("foo"); // 创建一个 symbol 并放入 symbol 注册表中,键为 "foo"
Symbol.for("foo"); // 从 symbol 注册表中读取键为"foo"的 symbol
Symbol.for("bar") === Symbol.for("bar"); // true,证明了上面说的
Symbol("bar") === Symbol("bar"); // false,Symbol() 函数每次都会返回新的一个 symbol
var sym = Symbol.for("mario");
sym.toString();
// "Symbol(mario)",mario 既是该 symbol 在 symbol 注册表中的键名,又是该 symbol 自身的描述字符串
</pre>
<p>为了防止冲突,最好给你要放入 symbol 注册表中的 symbol 带上键前缀。</p>
<pre class="brush: js">Symbol.for("mdn.foo");
Symbol.for("mdn.bar");
</pre>
<h2 id="规范">规范</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Specification</th>
<th scope="col">Status</th>
<th scope="col">Comment</th>
</tr>
<tr>
<td>{{SpecName('ES2015', '#sec-symbol.for', 'Symbol.for')}}</td>
<td>{{Spec2('ES2015')}}</td>
<td>Initial definition.</td>
</tr>
<tr>
<td>{{SpecName('ESDraft', '#sec-symbol.for', 'Symbol.for')}}</td>
<td>{{Spec2('ESDraft')}}</td>
<td> </td>
</tr>
</tbody>
</table>
<h2 id="浏览器兼容性">浏览器兼容性</h2>
{{Compat}}
<h2 id="See_Also">相关链接</h2>
<ul>
<li>{{jsxref("Symbol.keyFor()")}}</li>
</ul>
|