diff options
Diffstat (limited to 'files/zh-cn/web')
-rw-r--r-- | files/zh-cn/web/javascript/reference/global_objects/array/sort/index.html | 67 |
1 files changed, 53 insertions, 14 deletions
diff --git a/files/zh-cn/web/javascript/reference/global_objects/array/sort/index.html b/files/zh-cn/web/javascript/reference/global_objects/array/sort/index.html index e9f9808420..e4140bde3b 100644 --- a/files/zh-cn/web/javascript/reference/global_objects/array/sort/index.html +++ b/files/zh-cn/web/javascript/reference/global_objects/array/sort/index.html @@ -114,20 +114,20 @@ items.sort(function (a, b) { return (a.value - b.value) }); -<code class="language-js"><span class="comment token">// sort by name</span> -items<span class="punctuation token">.</span><span class="function token">sort</span><span class="punctuation token">(</span><span class="keyword token">function</span><span class="punctuation token">(</span>a<span class="punctuation token">,</span> b<span class="punctuation token">)</span> <span class="punctuation token">{</span> - <span class="keyword token">var</span> nameA <span class="operator token">=</span> a<span class="punctuation token">.</span>name<span class="punctuation token">.</span><span class="function token">toUpperCase</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> <span class="comment token">// ignore upper and lowercase</span> - <span class="keyword token">var</span> nameB <span class="operator token">=</span> b<span class="punctuation token">.</span>name<span class="punctuation token">.</span><span class="function token">toUpperCase</span><span class="punctuation token">(</span><span class="punctuation token">)</span><span class="punctuation token">;</span> <span class="comment token">// ignore upper and lowercase</span> - <span class="keyword token">if</span> <span class="punctuation token">(</span>nameA <span class="operator token"><</span> nameB<span class="punctuation token">)</span> <span class="punctuation token">{</span> - <span class="keyword token">return</span> <span class="operator token">-</span><span class="number token">1</span><span class="punctuation token">;</span> - <span class="punctuation token">}</span> - <span class="keyword token">if</span> <span class="punctuation token">(</span>nameA <span class="operator token">></span> nameB<span class="punctuation token">)</span> <span class="punctuation token">{</span> - <span class="keyword token">return</span> <span class="number token">1</span><span class="punctuation token">;</span> - <span class="punctuation token">}</span></code> - - <span class="comment token">// names must be equal</span> - <span class="keyword token">return</span> <span class="number token">0</span><span class="punctuation token">;</span> -<span class="punctuation token">}</span><span class="punctuation token">)</span><span class="punctuation token">;</span></pre> +// sort by name +items.sort(function(a, b) { + var nameA = a.name.toUpperCase(); // ignore upper and lowercase + var nameB = b.name.toUpperCase(); // ignore upper and lowercase + if (nameA < nameB) { + return -1; + } + if (nameA > nameB) { + return 1; + } + + // names must be equal + return 0; +});</pre> <h2 id="Examples" name="Examples">示例</h2> @@ -214,6 +214,45 @@ var result = mapped.map(function(el){ }); </pre> +<h3 id="sort_stability">排序稳定性</h3> + +<p>自 ES10(EcmaScript 2019)起,<a href="https://tc39.es/ecma262/#sec-array.prototype.sort">规范</a> 要求 <code>Array.prototype.sort</code> 为稳定排序。</p> +<p>假设有一个包含学生名字和年级的列表,已经将它按学生名字字母顺序进行预排序:</p> +<pre class="brush: js">const students = [ + { name: "Alex", grade: 15 }, + { name: "Devlin", grade: 15 }, + { name: "Eagle", grade: 13 }, + { name: "Sam", grade: 14 }, +]; +</pre> + +<p>对这个数组执行 <code>grade</code> 升序排序后:</p> + +<pre class="brush: js">students.sort((firstItem, secondItem) => firstItem.grade - secondItem.grade); +</pre> + +<p><code>students</code> 变量如下:</p> + +<pre class="brush: js">[ + { name: "Eagle", grade: 13 }, + { name: "Sam", grade: 14 }, + { name: "Alex", grade: 15 }, // grade 相同时维持原先的顺序 (稳定排序) + { name: "Devlin", grade: 15 }, // grade 相同时维持原先的顺序 (稳定排序) +]; +</pre> + +<p>注意,那些年级相同的学生(如 Alex 和 Devlin)会维持调用排序之前的顺序,这是稳定排序所确保的。</p> + +<p>ES10(EcmaScript 2019)以前没有要求稳定性,意味着你可能会得到以下结果:</p> + +<pre class="brush: js">[ + { name: "Eagle", grade: 13 }, + { name: "Sam", grade: 14 }, + { name: "Devlin", grade: 15 }, // 没有维持原先的顺序 + { name: "Alex", grade: 15 }, // 没有维持原先的顺序 +]; +</pre> + <h2 id="Specifications" name="Specifications">规范</h2> <table class="standard-table"> |