所述的JavaScript的Array.sort()方法被用来就地数组元素进行排序,并返回排序后的数组。此函数以字符串格式对元素进行排序。它对字符串数组有效,但对数字无效。例如:如果数字按字符串排序。 示例:本示例以字符串格式对数组元素进行排序。 输出: 升序排序后 输出: 升序排序后 输出: 升序排序后 输出: 排序数组
例:输入:[12,25,31,23,75,81,100] 错误的输出:[100、12、23、25、31、75、81] 正确的输出:[12、23、25、31、75、81、100]
<script> // Declare and initialize original array var marks = [12, 25, 31, 23, 75, 81, 100]; // Print Before Sortring Array document.write("Original Array</br>"); document.write(marks); document.write("</br>"); // Call sort fucntion marks.sort(); document.write("</br>After Sorting in Ascending Order</br>"); // Print Srted Numeric Array document.write(marks); </script>
原始阵列12,25,31,23,75,81,100
100,12,23,25,31,75,81
那么,如何对数字数组元素进行排序?
有两种方法可以对数字数组进行升序排序。
使用比较功能
通过创建循环
使用比较功能:我们可以创建一个比较功能,该功能返回负值,零值或正值。
句法:
函数(a,b){返回a-b}
负值(a> b)=> a将放置在b之前
零值(a == b)=>不变
正值(a <b)=> a将位于b之后
示例:本示例使用compare函数对数组元素进行升序排序。<script> // Declare and initialize an Array var marks = [12, 25, 31, 23, 75, 81, 100]; // Print Before sortring array document.write("Original Array</br>"); document.write(marks); document.write("</br>"); // Sort elements using compare method marks.sort(function(a, b){return a - b}); document.write("</br>After sorting in Ascending order</br>"); // Print sorted Numeric array document.write(marks); </script>
原始阵列12,25,31,23,75,81,100
12,23,25,31,75,81,100
现在,我们要以降序对数组进行排序,而不需要更改比较函数。
句法:
函数(a,b){返回b-a}
负值(b <a)=> a将位于b之后
零值(a == b)=>不变
正值(b> a)=> a将位于b之前
示例:本示例使用compare函数对数组元素进行降序排序。<script> // Declare and initialize an Array var marks = [12, 25, 31, 23, 75, 81, 100]; // Print Before sortring array document.write("Original Array</br>"); document.write(marks); document.write("</br>"); // Sort elements using compare method marks.sort(function(a, b){return b - a}); document.write("</br>After sorting in Ascending order</br>"); // Print sorted Numeric array document.write(marks); </script>
原始阵列
12,25,31,23,75,81,100
100,81,75,31,25,23,12
创建循环:我们还可以使用循环对数组元素进行排序。在这里,我们将使用冒泡排序(简单排序技术)对数组元素进行升序排序。
例:<script> // Sorting function function Numeric_sort(ar) { var i = 0, j; while (i < ar.length) { j = i + 1; while (j < ar.length) { if (ar[j] < ar[i]) { var temp = ar[i]; ar[i] = ar[j]; ar[j] = temp; } j++; } i++; } } // Original Array var arr = [1, 15, 10, 45, 27, 100]; // Print Before sortring array document.write("Original Array</br>"); document.write(arr); document.write("</br>"); // Function call Numeric_sort(arr); document.write("</br>Sorted Array</br>"); // Print sorted Numeric array document.write(arr); </script>
原始阵列
1,15,10,45,27,100
1,10,15,27,45,100
本网页所有视频内容由 imoviebox边看边下-网页视频下载, iurlBox网页地址收藏管理器 下载并得到。
ImovieBox网页视频下载器 下载地址: ImovieBox网页视频下载器-最新版本下载
本文章由: imapbox邮箱云存储,邮箱网盘,ImageBox 图片批量下载器,网页图片批量下载专家,网页图片批量下载器,获取到文章图片,imoviebox网页视频批量下载器,下载视频内容,为您提供.
阅读和此文章类似的: 全球云计算