javascript比较语义化版本号的实现代码


Posted in Javascript onSeptember 09, 2016

前言

所谓“语义化版本号”,就是在版本号中体现出语义,或者说版本号本身是有意义的,不再是随意给的一个数字。这个规范将版本号中每个数字的意义都做了比较严格的说明。当然,其中大部分内容还是沿用我们之前说过的业内的约定,所以,对于有版本号意识的开发者来说,接受这个规范是很容易的。

在移动端APP第三方开发中经常会碰到一些因为版本不同而造成JS SDK或JS API差异或支持的问题。对于移动前端来说,在实际第三方开发中可能会需要根据APP的版本号做一些特殊的业务逻辑处理。

语义化版本号

一般语义化版本号通常定义是这样的:

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.

这里需要注意的是根据我自己的业务逻辑当前版本小于比较版本返回 true。你可以根据自己的业务逻辑修改代码。

比如我们要获取微信的版本号,可以这样写:

var wechatInfo = navigator.userAgent.match(/MicroMessenger\/([\d\.]+)/i);
var currVer = wechatInfo[1];
if (VersionCompare(currVer, "6.2.5")) {
 //你的业务逻辑
}

注意:

时间仓促,这个方法仅仅作为普通的常用方法,没有提供只比较主版本或子版本的方法,而是比较最终的整个版本号。

总结

以上就是这篇文章的全部内容了,希望对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
jQuery Ajax 仿AjaxPro.Utility.RegisterTypeForAjax辅助方法
Sep 27 Javascript
可兼容IE的获取及设置cookie的jquery.cookie函数方法
Sep 02 Javascript
js将控件隐藏及display属性的使用介绍
Dec 30 Javascript
Node.js实现兼容IE789的文件上传进度条
Sep 02 Javascript
微信js-sdk上传与下载图片接口用法示例
Oct 12 Javascript
AngularJS路由Ui-router模块用法示例
May 29 Javascript
jQuery实现简单的回到顶部totop功能示例
Oct 16 jQuery
vue 全选与反选的实现方法(无Bug 新手看过来)
Feb 09 Javascript
解决vue+element 键盘回车事件导致页面刷新的问题
Aug 25 Javascript
如何用JavaScript实现功能齐全的单链表详解
Feb 11 Javascript
Jquery属性的获取/设置及样式添加/删除操作技巧分析
Dec 23 jQuery
Node快速切换版本、版本回退(降级)、版本更新(升级)
Jan 07 Javascript
js防阻塞加载的实现方法
Sep 09 #Javascript
Vuejs第一篇之入门教程详解(单向绑定、双向绑定、列表渲染、响应函数)
Sep 09 #Javascript
微信+angularJS的SPA应用中用router进行页面跳转,jssdk校验失败问题解决
Sep 09 #Javascript
Vuejs第十三篇之组件——杂项
Sep 09 #Javascript
jQuery属性选择器用法示例
Sep 09 #Javascript
浅谈jquery.form.js的ajaxSubmit和ajaxForm的使用
Sep 09 #Javascript
vuejs动态组件给子组件传递数据的方法详解
Sep 09 #Javascript
You might like
win7系统配置php+Apache+mysql环境的方法
2015/08/21 PHP
用Javascript数组处理多个字符串的连接问题
2009/08/20 Javascript
一款js和css代码压缩工具[附JAVA环境配置方法]
2010/04/16 Javascript
js DOM 元素ID就是全局变量
2012/09/20 Javascript
Javascript引用指针使用介绍
2012/11/07 Javascript
jQuery基础框架浅入剖析
2012/12/27 Javascript
js 自定义个性下拉选择框示例
2013/08/20 Javascript
jquery库或JS文件在eclipse下报错问题解决方法
2014/04/17 Javascript
json实现添加、遍历与删除属性的方法
2016/06/17 Javascript
js实现固定宽高滑动轮播图效果
2017/01/13 Javascript
Vue监听数组变化源码解析
2017/03/09 Javascript
xmlplus组件设计系列之分隔框(DividedBox)(8)
2017/05/02 Javascript
iscroll动态加载数据完美解决方法
2017/07/18 Javascript
加载 vue 远程代码的组件实例详解
2017/11/20 Javascript
JS 中可以提升幸福度的小技巧(可以识别更多另类写法)
2018/07/28 Javascript
jquery判断滚动条距离顶部的距离方法
2018/09/05 jQuery
详解js常用分割取字符串的方法
2019/05/15 Javascript
vue+element实现图片上传及裁剪功能
2020/06/29 Javascript
[02:30]DOTA2英雄基础教程 暗影恶魔
2013/12/17 DOTA
python实现文件分组复制到不同目录的例子
2014/06/04 Python
Python 序列化 pickle/cPickle模块使用介绍
2014/11/30 Python
Python解析json文件相关知识学习
2016/03/01 Python
Python基于贪心算法解决背包问题示例
2017/11/27 Python
详解python string类型 bytes类型 bytearray类型
2017/12/16 Python
详解Python最长公共子串和最长公共子序列的实现
2018/07/07 Python
Django集成CAS单点登录的方法示例
2019/06/10 Python
Python使用Beautiful Soup爬取豆瓣音乐排行榜过程解析
2019/08/15 Python
英国二手物品交易网站:Preloved
2017/10/06 全球购物
英国国家美术馆商店:National Gallery
2019/05/01 全球购物
奥巴马演讲稿
2014/01/08 职场文书
优秀教师事迹简介
2014/02/02 职场文书
有多年工作经验的自我评价
2014/03/02 职场文书
《高尔基和他的儿子》教学反思
2014/04/09 职场文书
工作岗位职责范本
2015/02/15 职场文书
2016年习总书记讲话学习心得体会
2016/01/20 职场文书
详解MySQL的半同步
2021/04/22 MySQL