mirror of
https://github.com/fofolee/uTools-Manuals.git
synced 2026-02-27 09:32:01 +08:00
语法高亮,滚动条美化,设置页面调整
This commit is contained in:
@@ -28,23 +28,23 @@
|
||||
<h2 id="示例">示例</h2>
|
||||
<h3 id="函数声明的名称">函数声明的名称</h3>
|
||||
<p> <code>name</code> 属性返回一个函数声明的名称。</p>
|
||||
<pre class="brush:js">function doSomething() { }
|
||||
<pre><code class="language-js">function doSomething() { }
|
||||
doSomething.name; // "doSomething"
|
||||
</pre>
|
||||
</code></pre>
|
||||
<h3 id="构造函数的名称">构造函数的名称</h3>
|
||||
<p>使用<code>new Function(...)</code>语法创建的函数或只是 <code>Function(...) create</code> <a href="Reference/Function" title="此页面仍未被本地化, 期待您的翻译!"><code>Function</code></a>对象及其名称为“anonymous”。</p>
|
||||
<pre class="brush: js">(new Function).name; // "anonymous"</pre>
|
||||
<pre><code class="language-javascript">(new Function).name; // "anonymous"</code></pre>
|
||||
<h3 id="推断函数名称">推断函数名称</h3>
|
||||
<p>变量和方法可以从句法位置推断匿名函数的名称(ECMAScript 2015中新增)。</p>
|
||||
<pre class="brush: js">var f = function() {};
|
||||
<pre><code class="language-javascript">var f = function() {};
|
||||
var object = {
|
||||
someMethod: function() {}
|
||||
};
|
||||
|
||||
console.log(f.name); // "f"
|
||||
console.log(object.someMethod.name); // "someMethod"</pre>
|
||||
console.log(object.someMethod.name); // "someMethod"</code></pre>
|
||||
<p style="color: rgb(77, 78, 83);">你可以在 <a href="Reference/Operators/Function" title="function 关键字可以用来在一个表达式中定义一个函数。">函数表达式</a>中定义函数的名称:</p>
|
||||
<pre class="brush:js">var object = {
|
||||
<pre><code class="language-js">var object = {
|
||||
someMethod: function object_someMethod() {}
|
||||
};
|
||||
|
||||
@@ -52,70 +52,70 @@ console.log(object.someMethod.name); // "object_someMethod"
|
||||
|
||||
try { object_someMethod } catch(e) { alert(e); }
|
||||
// ReferenceError: object_someMethod is not defined
|
||||
</pre>
|
||||
</code></pre>
|
||||
<p>你不能更改函数的名称,此属性是只读的:</p>
|
||||
<div class="hidden">
|
||||
<p>Example below contradicts with what is said at the beginning of this section and doesn't work as described.</p>
|
||||
</div>
|
||||
<pre class="brush: js">var object = {
|
||||
<pre><code class="language-javascript">var object = {
|
||||
// anonymous
|
||||
someMethod: function() {}
|
||||
};
|
||||
|
||||
object.someMethod.name = 'otherMethod';
|
||||
console.log(object.someMethod.name); // someMethod</pre>
|
||||
console.log(object.someMethod.name); // someMethod</code></pre>
|
||||
<p>要更改它,可以使用<a href="Reference/Global_Objects/Object/defineProperty" title="Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象。"><code>Object.defineProperty()</code></a>。</p>
|
||||
<h3 id="简写方法的名称">简写方法的名称</h3>
|
||||
<pre class="brush: js">var o = {
|
||||
<pre><code class="language-javascript">var o = {
|
||||
foo(){}
|
||||
};
|
||||
o.foo.name; // "foo";</pre>
|
||||
o.foo.name; // "foo";</code></pre>
|
||||
<h3 id="绑定函数的名称">绑定函数的名称</h3>
|
||||
<p><a href="Reference/Global_Objects/Function/bind" title="bind()方法创建一个新的函数,在调用时设置this关键字为提供的值。并在调用新函数时,将给定参数列表作为原函数的参数序列的前若干项。"><code>Function.bind()</code></a> 所创建的函数将会在函数的名称前加上"bound " 。</p>
|
||||
<pre class="brush: js">function foo() {};
|
||||
foo.bind({}).name; // "bound foo"</pre>
|
||||
<pre><code class="language-javascript">function foo() {};
|
||||
foo.bind({}).name; // "bound foo"</code></pre>
|
||||
<h3 id="getters_和_setters_的函数名">getters 和 setters 的函数名</h3>
|
||||
<p>当通过 <code><a href="Reference/Functions/get">get</a></code> 和 <code><a href="Reference/Functions/set">set</a></code> 访问器来存取属性时, "get" 或 "set" 会出现在函数名称前。</p>
|
||||
<pre class="brush: js">var o = {
|
||||
<pre><code class="language-javascript">var o = {
|
||||
get foo(){},
|
||||
set foo(x){}
|
||||
};
|
||||
|
||||
var descriptor = Object.getOwnPropertyDescriptor(o, "foo");
|
||||
descriptor.get.name; // "get foo"
|
||||
descriptor.set.name; // "set foo";</pre>
|
||||
descriptor.set.name; // "set foo";</code></pre>
|
||||
<h3 id="类中的函数名称">类中的函数名称</h3>
|
||||
<p>你可以使用<code>obj.constructor.name</code>来检查对象的“类”(但请务必阅读以下警告):</p>
|
||||
<pre class="brush: js">function Foo() {} // ES2015 Syntax: class Foo {}
|
||||
<pre><code class="language-javascript">function Foo() {} // ES2015 Syntax: class Foo {}
|
||||
|
||||
var fooInstance = new Foo();
|
||||
console.log(fooInstance.constructor.name); // logs "Foo"</pre>
|
||||
console.log(fooInstance.constructor.name); // logs "Foo"</code></pre>
|
||||
<div class="warning">
|
||||
<p><strong>警告:</strong>脚本解释器只有在函数没有名为name的属性时才会设置内置的<code>Function.name</code>属性(参见 <a class="external" href="https://www.ecma-international.org/ecma-262/6.0/#sec-setfunctionname" rel="noopener">9.2.11 of the ECMAScript2015 Language Specification</a>)。但是,ES2015规定由关键字<em>static</em>修饰的静态方法也会被认为是类的属性(ECMAScript2015, <a class="external" href="https://www.ecma-international.org/ecma-262/6.0/#sec-runtime-semantics-classdefinitionevaluation" rel="noopener">14.5.14.21.b</a> + <a class="external" href="https://www.ecma-international.org/ecma-262/6.0/#sec-object-initializer-runtime-semantics-propertydefinitionevaluation" rel="noopener">12.2.6.9</a>)。</p>
|
||||
</div>
|
||||
<p>因此,我们无法获取具有静态方法属性<code>name()</code>的几乎任何类的类名称:</p>
|
||||
<pre class="brush: js">class Foo {
|
||||
<pre><code class="language-javascript">class Foo {
|
||||
constructor() {}
|
||||
static name() {}
|
||||
}
|
||||
</pre>
|
||||
</code></pre>
|
||||
<p>使用<code>static name()</code>方法<code>Foo.name</code>不再保存实际的类名称,而是引用<code>name()</code>函数对象。 ES2015语法中的上述类定义将在Chrome或Firefox中运行,类似于ES5语法中的以下代码段:</p>
|
||||
<pre class="brush: js">function Foo() {}
|
||||
<pre><code class="language-javascript">function Foo() {}
|
||||
Object.defineProperty(Foo, 'name', { writable: true });
|
||||
Foo.name = function() {};
|
||||
</pre>
|
||||
</code></pre>
|
||||
<p>通过<code>fooInstance.constructor.name</code>获取<code>fooInstance</code>类不会给我们所有的类名,而是静态类方法的引用。 例如:</p>
|
||||
<pre class="brush: js">var fooInstance = new Foo();
|
||||
console.log(fooInstance.constructor.name); // logs function name()</pre>
|
||||
<pre><code class="language-javascript">var fooInstance = new Foo();
|
||||
console.log(fooInstance.constructor.name); // logs function name()</code></pre>
|
||||
<p>你也可以从ES5语法示例中看到,在Chrome或Firefox的中静态定义的<code>Foo.name</code>变得可写。内置定义在没有自定义静态定义时是只读的:</p>
|
||||
<pre class="brush: js">Foo.name = 'Hello';
|
||||
<pre><code class="language-javascript">Foo.name = 'Hello';
|
||||
console.log(Foo.name);
|
||||
//如果Foo具有静态name()属性,则输出“Hello”,否则为“Foo”
|
||||
</pre>
|
||||
</code></pre>
|
||||
<p>因此,你不能依赖内置的<code>Function.name</code>属性来保持一个类的名称。</p>
|
||||
<h3 id="Symbol作为函数名称">Symbol作为函数名称</h3>
|
||||
<p>如果<a href="Reference/Global_Objects/Symbol" title='Symbol()函数会返回symbol类型的值,该类型具有静态属性和静态方法。它的静态属性会暴露几个内建的成员对象;它的静态方法会暴露全局的symbol注册,且类似于内建对象类,但作为构造函数来说它并不完整,因为它不支持语法:"new Symbol()"。'><code>Symbol</code></a> 被用于函数名称,并且这个symbol具有相应的描述符,那么方法的名字就是方括号中的描述符。</p>
|
||||
<pre class="brush: js">var sym1 = Symbol("foo");
|
||||
<pre><code class="language-javascript">var sym1 = Symbol("foo");
|
||||
var sym2 = Symbol();
|
||||
var o = {
|
||||
[sym1]: function(){},
|
||||
@@ -124,29 +124,29 @@ var o = {
|
||||
|
||||
o[sym1].name; // "[foo]"
|
||||
o[sym2].name; // ""
|
||||
</pre>
|
||||
</code></pre>
|
||||
<h2 id="JavaScript_压缩和_minifiers">JavaScript 压缩和 minifiers</h2>
|
||||
<div class="warning">
|
||||
<p><strong>警告:</strong>当使用<code>Function.name</code>和那些JavaScript压缩器(minifiers)或混淆器进行源码转换时要小心。这些工具通常用作JavaScript构建管道的一部分,以在程序部署到生产之前减少程序的大小。但这种转换通常会在构建时更改函数的名称。</p>
|
||||
</div>
|
||||
<p>例如下面的代码:</p>
|
||||
<pre class="brush: js">function Foo() {};
|
||||
<pre><code class="language-javascript">function Foo() {};
|
||||
var foo = new Foo();
|
||||
|
||||
if (foo.constructor.name === 'Foo') {
|
||||
console.log("'foo' is an instance of 'Foo'");
|
||||
} else {
|
||||
console.log('Oops!');
|
||||
}</pre>
|
||||
}</code></pre>
|
||||
<p>可能被压缩为:</p>
|
||||
<pre class="brush: js">function a() {};
|
||||
<pre><code class="language-javascript">function a() {};
|
||||
var b = new a();
|
||||
if (b.constructor.name === 'Foo') {
|
||||
console.log("'foo' is an instance of 'Foo'");
|
||||
} else {
|
||||
console.log('Oops!');
|
||||
}
|
||||
</pre>
|
||||
</code></pre>
|
||||
<p>在未压缩版本中,程序运行到真实分支并打印<code>'foo' is an instance of 'Foo'</code>。 而在压缩版本中,它的行为不同,并且进入else分支。如果您依赖于<code>Function.name</code>,就像上面的示例一样,确保您的构建管道不会更改函数名称,也不要假定函数具有特定的名称。</p>
|
||||
<article>
|
||||
<h2 id="规范">规范</h2>
|
||||
|
||||
Reference in New Issue
Block a user