mirror of
https://github.com/fofolee/uTools-Manuals.git
synced 2025-06-12 18:14:42 +08:00
120 lines
5.5 KiB
HTML
120 lines
5.5 KiB
HTML
<article id="wikiArticle">
|
||
<div></div>
|
||
<p><code><strong>Reflect</strong></code><strong><code>.construct()</code></strong> 方法的行为有点像 <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/new"><code>new</code> 操作符</a> 构造函数 , 相当于运行 <code>new target(...args)</code>.</p>
|
||
<h2 id="语法">语法</h2>
|
||
<pre><code class="language-javascript">Reflect.construct(target, argumentsList[, newTarget])
|
||
</code></pre>
|
||
<h3 id="参数">参数</h3>
|
||
<dl>
|
||
<dt><code>target</code></dt>
|
||
<dd>被运行的目标函数</dd>
|
||
<dt><code>argumentsList</code></dt>
|
||
<dd>调用构造函数的数组或者伪数组</dd>
|
||
<dt><code>newTarget</code> <span class="inlineIndicator optional optionalInline">可选</span></dt>
|
||
<dd>该参数为构造函数, 参考 <code><a href="/en-US/docs/Web/JavaScript/Reference/Operators/new.target">new.target</a></code> 操作符,如果没有newTarget参数, 默认和<code>target一样</code></dd>
|
||
</dl>
|
||
<h3 id="Errors_thrown">Errors thrown</h3>
|
||
<p>抛出<a href="Reference/Global_Objects/TypeError" title="TypeError(类型错误) 对象用来表示值的类型非预期类型时发生的错误。"><code>TypeError</code></a>,异常, 如果target或者newTarget不是构造函数</p>
|
||
<h2 id="描述">描述</h2>
|
||
<p><code>Reflect.construct允许你使用可变的参数来调用构造函数</code> </p>
|
||
<pre><code class="language-javascript">var obj = new Foo(...args);
|
||
var obj = Reflect.construct(Foo, args); </code></pre>
|
||
<h2 id="实例">实例</h2>
|
||
<h3 id="使用_Reflect.construct()">使用 <code>Reflect.construct()</code></h3>
|
||
<pre><code class="language-javascript">var d = Reflect.construct(Date, [1776, 6, 4]);
|
||
d instanceof Date; // true
|
||
d.getFullYear(); // 1776
|
||
</code></pre>
|
||
<h3 id="使用_newTarget_参数">使用 <code>newTarget</code> 参数</h3>
|
||
<p>参考 <a href="/en-US/docs/Web/JavaScript/Reference/Classes">classes</a> 获取更多有关子类的信息, 和<code><a href="/en-US/docs/Web/JavaScript/Reference/Operators/new.target">new.target</a></code> 操作符的信息</p>
|
||
<pre><code class="language-javascript">function someConstructor() {}
|
||
var result = Reflect.construct(Array, [], someConstructor);
|
||
|
||
Reflect.getPrototypeOf(result); // 输出:someConstructor.prototype
|
||
Array.isArray(result); // true
|
||
</code></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><a class="external" href="https://www.ecma-international.org/ecma-262/6.0/#sec-reflect.construct" hreflang="en" lang="en" rel="noopener">ECMAScript 2015 (6th Edition, ECMA-262)<br/><small lang="zh-CN">Reflect.construct</small></a></td>
|
||
<td><span class="spec-Standard">Standard</span></td>
|
||
<td>Initial definition.</td>
|
||
</tr>
|
||
<tr>
|
||
<td><a class="external" href="https://tc39.github.io/ecma262/#sec-reflect.construct" hreflang="en" lang="en" rel="noopener">ECMAScript Latest Draft (ECMA-262)<br/><small lang="zh-CN">Reflect.construct</small></a></td>
|
||
<td><span class="spec-Draft">Draft</span></td>
|
||
<td> </td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
<h2 id="浏览器兼容">浏览器兼容</h2>
|
||
<p></p><div class="blockIndicator warning"><strong><a class="external" href="https://github.com/mdn/browser-compat-data" rel="noopener">We're converting our compatibility data into a machine-readable JSON format</a></strong>.
|
||
This compatibility table still uses the old format,
|
||
because we haven't yet converted the data it contains.
|
||
<strong><a class="new" href="/zh-CN/docs/MDN/Contribute/Structures/Compatibility_tables" rel="nofollow">Find out how you can help!</a></strong></div>
|
||
<div class="htab">
|
||
<a id="AutoCompatibilityTable" name="AutoCompatibilityTable"></a>
|
||
<ul>
|
||
<li class="selected"><a>Desktop</a></li>
|
||
<li><a>Mobile</a></li>
|
||
</ul>
|
||
</div><p></p>
|
||
<div id="compat-desktop">
|
||
<table class="compat-table">
|
||
<tbody>
|
||
<tr>
|
||
<th>Feature</th>
|
||
<th>Chrome</th>
|
||
<th>Firefox (Gecko)</th>
|
||
<th>Internet Explorer</th>
|
||
<th>Opera</th>
|
||
<th>Safari</th>
|
||
</tr>
|
||
<tr>
|
||
<td>Basic support</td>
|
||
<td>49</td>
|
||
<td><a href="/en-US/Firefox/Releases/42" title="Released on 2015-11-03.">42</a> (42)</td>
|
||
<td><span style="color: #f00;">未实现</span></td>
|
||
<td><span style="color: #f00;">未实现</span></td>
|
||
<td><span style="color: #f00;">未实现</span></td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
<div id="compat-mobile">
|
||
<table class="compat-table">
|
||
<tbody>
|
||
<tr>
|
||
<th>Feature</th>
|
||
<th>Android</th>
|
||
<th>Chrome for Android</th>
|
||
<th>Firefox Mobile (Gecko)</th>
|
||
<th>IE Mobile</th>
|
||
<th>Opera Mobile</th>
|
||
<th>Safari Mobile</th>
|
||
</tr>
|
||
<tr>
|
||
<td>Basic support</td>
|
||
<td><span style="color: #f00;">未实现</span></td>
|
||
<td><span style="color: #f00;">未实现</span></td>
|
||
<td>42.0 (42)</td>
|
||
<td><span style="color: #f00;">未实现</span></td>
|
||
<td><span style="color: #f00;">未实现</span></td>
|
||
<td><span style="color: #f00;">未实现</span></td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
<h2 id="相关链接">相关链接</h2>
|
||
<ul>
|
||
<li><a href="Reference/Global_Objects/Reflect" title="Reflect 是一个内置的对象,它提供拦截 JavaScript 操作的方法。这些方法与处理器对象的方法相同。Reflect不是一个函数对象,因此它是不可构造的。"><code>Reflect</code></a></li>
|
||
<li><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/new"><code>new</code></a></li>
|
||
<li><code><a href="/en-US/docs/Web/JavaScript/Reference/Operators/new.target">new.target</a></code></li>
|
||
</ul>
|
||
</article> |