var a = [1,2,3,4,5]; //定义数组 a.reverse(); //颠倒数组顺序 console.log(a); //返回数组[5,4,3,2,1]
var a = ["a","e","d","b","c"]; //定义数组 a.sort(); //按字母顺序对元素进行排序 console.log(a); //返回数组[a,b,c,d,e]
var a = ["aba","baa","aab"]; 定义数组 a.sort(); //按字母顺序对元素进行排序 console.log(a); //返回数组[aab,aba,baa]在排序时,首先比较每个元素的第 1 个字符,在第 1 个字符相同的情况下,再比较第 2 个字符,以此类推。
function f(a,b) { //排序函数 return (a - b); //返回比较参数 } var a = [3,1,2,4,5,7,6,8,0,9]; //定义数组 a.sort(f); //根据数字大小由小到大进行排序 console.log(a); //返回数组[0,1,2,3,4,5,6,4,7,8,9]如果按从大到小的顺序执行,则让返回值取反即可。代码如下:
function f(a,b) { //排序函数 return -(a - b); //取反并返回比较参数 } var a = [3,1,2,4,5,7,6,8,0,9]; //定义数组 a.sort(f); //根据数字大小由小到大进行排序 console.log(a); //返回数组[9,8,7,6,5,4,3,2,1,0]
function f(a, b) { //排序函数 var a = a % 2; //获取参数a的奇偶性 var b = b % 2; //获取参数b的奇偶性 if (a == 0) return 1; //如果参数a为偶数,则排在左边 if (b == 0) return -1; //如果参数b为偶数,则排在右边 } var a = [3,1,2,4,5,7,6,8,0,9]; //定义数组 a.sort(f); //根据数字大小由大到小进行排序 console.log(a); //返回数组[3,1,5,7,9,0,8,6,4,2]sort() 方法在调用排序函数时,对每个元素值传递给排序函数,如果元素值为偶数,则保留其位置不动;如果元素值为奇数,则调换参数 a 和 b 的显示顺序,从而实现对数组中所有元素执行奇偶排序。如果希望偶数排在前面,奇数排在后面,则只需要取返回值。排序函数如下。
function f(a, b) { var a = a % 2; var b = b % 2; if (a == 0) return -1; if (b == 0) return 1; }
var a = ["aB", "Ab", "Ba", "bA"]; //定义数组 a.sort(); //默认方法排序 console.log(a); //返回数组["Ab", "Ba", "aB", "bA"]大写字母总是排在左侧,如果让小写字母总是排在左侧,可以设计:
function f(a ,b) { return (a < b); } var a = ["aB", "Ab", "Ba", "bA"]; //定义数组 a.sort(); //默认方法排序 console.log(a); //返回数组["Ab", "Ba", "aB", "bA"]对于字母比较大小时,JavaScript 是根据字符编码大小来决定的,当为 true 时,则返回 1;为 false 时,则返回 -1。
function f(a, b) { var a = a.toLowerCase; var b = b.toLowerCase; if (a < b) { return 1; } else { return -1; } } var a = ["aB", "Ab", "Ba", "bA"]; //定义数组 a.sort(); //默认方法排序 console.log(a); //返回数组["aB", "Ab", "Ba", "bA"]如果要调整排列顺序,则设置返回值取反即可。
function f(a, b) { //排序函数 if (a > Math.floor(a)) return 1; //如果a是浮点数,则调换位置 if (b > Math.floor(b)) return -1; //如果b是浮点数,则调换位置 } var a = [3.5555, 1.23456, 3, 2.11111, 5, 7, 3]; //定义数组 a.sort(f); //进行筛选 console.log(a); //返回数组[3,5,7,3,2.11111,1.23456,3.55555]如果要调整排序顺序,则设置返回值取反即可。
Copyright © 广州京杭网络科技有限公司 2005-2025 版权所有 粤ICP备16019765号
广州京杭网络科技有限公司 版权所有