在最近的一次开发过程中,遇到了一个需求,需要获取所有同类型中最新的版本号,后端没有这个接口,只能获取全部版本号数据在前端处理。一开始就想到了使用数组的sort()方法去处理,但是因为版本号的命名不规律等问题,自己写的始终有问题,后来也是网上看了大神们的代码,才进行了补完。现在整理整理,以备后用。
一、对比版本号大小
方法一: 转成数字进行对比(适用于两个比较有规律命名的版本号,且版本号为数字,不包含字母及特殊符号)
function compare(a, b) {
// 得到去除'.'后的字符串
var aa = a.split('.').join(''); // 也可以使用replace的方法 repalce(/\./g, '')
var bb = b.split('.').join('');
console.log(aa, bb); // '1055' '121'
// 获取两个新字符串的最大长度
var maxl = Math.max(aa.length, bb.length);
console.log(maxl); // 4
// 使用'0'补齐字符串长度
// 这里要注意,使用number类型进行比较; 使用string类型进行比较,是通过ASCII码比较,不准确
// 如果是数字字符串与纯数字比较,会隐式转成纯数字后进行比较,则不存在该问题
var aaa = parInt(aa + ((maxl - aa.length) > 0 ? (maxl - aa.length)*0 : ''));
var bbb = parInt(bb + ((maxl - bb.length) > 0 ? (maxl - bb.length)*0 : ''));
console.log(aaa,bbb); // 1055 1210
// 比较版本大小
if (aaa === bbb) {
return '两者相等';
} else {
return aaa > bbb ? a : b;
}
};
// 定义两个版本号变量
var a = '1.0.55';
var b = '1.2.1';
compare(a, b); // b
方法二: (待续。。。)
二、对版本号数组进行排序
function compareArr(arr) {
// 利用Array的 sort()方法进行比较排序
arr.sort(function (a,b) {
var aa = a.split('.')
var bb = b.split('.')
var maxL = Math.max(aa.length, bb.length);
// 补齐数组, 统一length
var aaa = aa.concat(new Array(maxL - aa.length).fill('0'))
var bbb = bb.concat(new Array(maxL - bb.length).fill('0'))
// 进行数值大小比较
var r = null
for (let i = 0; i < maxL; i++) {
if (parseInt(aaa[i]) < parseInt(bbb[i])) {
r = 1
break
} else if (parseInt(aaa[i]) > parseInt(bbb[i])) {
r = -1
break
} else if (i === maxL && aaa[i] === bbb[i]) {
r = 0
}
}
return r
})
}
var versionArr = [ '1.0.1', '1.05.1', '1.2.5555', '1.1.3.2', '1', '1.10']
console.log(compareArr(versionArr)) // ["1.10", "1.05.1", "1.2.5555", "1.1.3.2", "1.0.1", "1"]
注:以上方法,参考了网上的一些写法,并进行了修改完善。
统一数组长度,使用最大长度进行循环比较,而不是使用最小长度进行比较,避免了版本号风格不统一的问题。
使用了数字比较而不是字符串比较,避免不准确的bug。
不足: 没有总结版本号中包含字母或者特殊符号等的比较;只适用于版本号为数字标记的。