语法高亮,滚动条美化,设置页面调整

This commit is contained in:
fofolee
2019-04-19 02:41:09 +08:00
parent 1e8f76c000
commit 359d29ee0b
1590 changed files with 12328 additions and 11441 deletions

View File

@@ -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>