javascript比較語義化版本號的實現(xiàn)代碼
前言
所謂“語義化版本號”,就是在版本號中體現(xiàn)出語義,或者說版本號本身是有意義的,不再是隨意給的一個數(shù)字。這個規(guī)范將版本號中每個數(shù)字的意義都做了比較嚴格的說明。當然,其中大部分內(nèi)容還是沿用我們之前說過的業(yè)內(nèi)的約定,所以,對于有版本號意識的開發(fā)者來說,接受這個規(guī)范是很容易的。
在移動端APP第三方開發(fā)中經(jīng)常會碰到一些因為版本不同而造成JS SDK或JS API差異或支持的問題。對于移動前端來說,在實際第三方開發(fā)中可能會需要根據(jù)APP的版本號做一些特殊的業(yè)務邏輯處理。
語義化版本號
一般語義化版本號通常定義是這樣的:
Major_Version_Number.Minor_Version_Number[.Revision_Number[.Build_Number]] 主版本號 .子版本號 [.修正版本號 [.編譯版本號 ]]
定界符一般使用.
語義化版本號比較方法
這樣我們可以做版本號比較,這里提供一個粗陋的方法:
/**
* 版本比較 VersionCompare
* @param {String} currVer 當前版本.
* @param {String} promoteVer 比較版本.
* @return {Boolean} false 當前版本小于比較版本返回 true.
*
* 使用
* VersionCompare("6.3","5.2.5"); // false.
* VersionCompare("6.1", "6.1"); // false.
* VersionCompare("6.1.5", "6.2"); // true.
*/
var VersionCompare = function (currVer, promoteVer) {
currVer = currVer || "0.0.0";
promoteVer = promoteVer || "0.0.0";
if (currVer == promoteVer) return false;
var currVerArr = currVer.split(".");
var promoteVerArr = promoteVer.split(".");
var len = Math.max(currVerArr.length, promoteVerArr.length);
for (var i = 0; i < len; i++) {
var proVal = ~~promoteVerArr[i],
curVal = ~~currVerArr[i];
if (proVal < curVal) {
return false;
} else if (proVal > curVal) {
return true;
}
}
return false;
};
使用也很簡單:
VersionCompare("6.3","5.2.5"); // false.
VersionCompare("6.1", "6.1"); // false.
VersionCompare("6.1.5", "6.2"); // true.
這里需要注意的是根據(jù)我自己的業(yè)務邏輯當前版本小于比較版本返回 true。你可以根據(jù)自己的業(yè)務邏輯修改代碼。
比如我們要獲取微信的版本號,可以這樣寫:
var wechatInfo = navigator.userAgent.match(/MicroMessenger\/([\d\.]+)/i);
var currVer = wechatInfo[1];
if (VersionCompare(currVer, "6.2.5")) {
//你的業(yè)務邏輯
}
注意:
時間倉促,這個方法僅僅作為普通的常用方法,沒有提供只比較主版本或子版本的方法,而是比較最終的整個版本號。
總結
以上就是這篇文章的全部內(nèi)容了,希望對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關文章
JavaScript實現(xiàn)棧結構Stack過程詳解
這篇文章主要介紹了JavaScript實現(xiàn)棧結構Stack過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03
關于UTF-8的客戶端用AJAX方式獲取GB2312的服務器端亂碼問題的解決辦法
客戶端是UTF-8編碼,這也是現(xiàn)在大家公認的標準編碼在這種情況下,實用AJAX異步獲取GB2312編碼的服務器端信息時,不可避免的要遇到漢字亂碼問題2010-11-11
詳解webpack的文件監(jiān)聽實現(xiàn)(熱更新)
這篇文章主要介紹了詳解webpack的文件監(jiān)聽實現(xiàn)(熱更新),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-09-09

