在数组排序中有一个sort()方法,sort()方法可以说分为两种一种是文字数组排序,一种是数字数组排序。
文字数组排序的主要机制是按unicode码顺序排列
起代码如下:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="Generator" content="EditPlus®">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<title>Document</title>
<script type="text/javascript">
arry1=new Array("Hello","world","javascript");
document.write("排序前"+arry1+"<br/>");
document.write("排序后"+arry1.sort());
</script>
</head>
<body>
</body>
</html>
运行结果:
接下来是主要的就是sort的数字数组排序:
代码如下:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="Generator" content="EditPlus®">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<title>Document</title>
<script type="text/javascript">
function paixu(a,b)
{
return a-b;
}
arry1=new Array(15,5,20,39,52,18,6);
document.write("排序前"+arry1+"<br/>");
document.write("排序后"+arry1.sort(paixu));
</script>
</head>
<body>
</body>
</html>
这里我一开始学习的时候也是不清楚a和b是什么东西,为什么return a-b;就能升序,也查阅过一些专业的书籍,对这里都没有做详细的解释,我们可以这样认为,学过数据结构的同学都应该知道一个冒泡排序吧,这个原理和冒泡排序是一样的,,,如果没有学过数据结构的同学可以这样想,我每次从数组中取一个元素和剩余的元素相比较,如果当前元素大于数组中的元素,那么它们俩个就交换,否则不变,那么这里面的a就是你取出来要与数组中其它元素相比较的元素,,而b就是你数组中剩下的元素,当然上面的代码也可以这样写:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="Generator" content="EditPlus®">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<title>Document</title>
<script type="text/javascript">
function paixu(a,b)
{
return a>b;
}
arry1=new Array(15,5,20,39,52,18,6);
document.write("排序前"+arry1+"<br/>");
document.write("排序后"+arry1.sort(paixu));
</script>
</head>
<body>
</body>
</html>
结果都是一样的。