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 相关文章推荐
JavaScript 浏览器验证代码(来自discuz)
Jul 17 Javascript
window.open关于浏览器拦截问题分析及解决方法
Feb 05 Javascript
js中单引号与双引号冲突问题解决方法
Oct 04 Javascript
javascript垃圾收集机制与内存泄漏详细解析
Nov 11 Javascript
详解JS面向对象编程
Jan 24 Javascript
XMLHttpRequest Level 2 使用指南
Aug 26 Javascript
jQuery自定义组件(导入组件)
Nov 08 Javascript
详解React Native网络请求fetch简单封装
Aug 10 Javascript
JS轮播图实现简单代码
Feb 19 Javascript
Express下采用bcryptjs进行密码加密的方法
Feb 07 Javascript
利用vue重构有赞商城的思路以及总结整理
Feb 21 Javascript
vue3实现v-model原理详解
Oct 09 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
php操作excel文件 基于phpexcel
2010/07/02 PHP
ThinkPHP中url隐藏入口文件后接收alipay传值的方法
2014/12/09 PHP
Laravel5.* 打印出执行的sql语句的方法
2017/07/24 PHP
Extjs Ext.MessageBox.confirm 确认对话框详解
2010/04/02 Javascript
使用jquery实现图文切换效果另加特效
2013/01/20 Javascript
javascript 获取浏览器版本
2015/01/21 Javascript
让图片跳跃起来  javascript图片轮播特效
2016/02/16 Javascript
jQuery设置Easyui校验规则(推荐)
2016/11/21 Javascript
Vue 仿百度搜索功能实现代码
2017/02/16 Javascript
微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(二)
2017/05/11 Javascript
nodejs爬虫初试superagent和cheerio
2018/03/05 NodeJs
jQuery阻止事件冒泡实例分析
2018/07/03 jQuery
react组件从搭建脚手架到在npm发布的步骤实现
2019/01/09 Javascript
解决vuex数据异步造成初始化的时候没值报错问题
2019/11/13 Javascript
微信小程序调用后台service教程详解
2020/11/06 Javascript
[49:30]DOTA2-DPC中国联赛正赛 Dragon vs Dynasty BO3 第二场 3月4日
2021/03/11 DOTA
Python中的包和模块实例
2014/11/22 Python
Python字符串中查找子串小技巧
2015/04/10 Python
简单易懂的python环境安装教程
2017/07/13 Python
Python调用系统底层API播放wav文件的方法
2017/08/11 Python
Python解决走迷宫问题算法示例
2018/07/27 Python
python实现弹窗祝福效果
2019/04/07 Python
利用Python复制文件的9种方法总结
2019/09/02 Python
Python标准库itertools的使用方法
2020/01/17 Python
常用的10个Python实用小技巧
2020/08/10 Python
Python使用for生成列表实现过程解析
2020/09/22 Python
pycharm激活码2020最新分享适用pycharm2020最新版亲测可用
2020/11/22 Python
python代码实现图书管理系统
2020/11/30 Python
详解python3 GUI刷屏器(附源码)
2021/02/18 Python
Weekendesk意大利:探索多种引人入胜的周末主题
2016/10/14 全球购物
实习自我鉴定
2013/12/15 职场文书
支教自我鉴定
2014/01/18 职场文书
指导教师评语
2014/04/26 职场文书
公司租房协议书
2014/10/14 职场文书
《水浒传》读后感3篇(范文)
2019/09/19 职场文书
【海涛DOTA解说】EVE女子战队独家录像加ZSMJ神牛两连发
2022/04/01 DOTA