function HIBC_CheckCode(code) {     var nonCheckCode = code.substr(0, code.length - 1);     var arr = nonCheckCode.split("");     var sum = 0;     var arrayDic = new Array();     arrayDic["0"] = "0";     arrayDic["1"] = "1";     arrayDic["2"] = "2";     arrayDic["3"] = "3";     arrayDic["4"] = "4";     arrayDic["5"] = "5";     arrayDic["6"] = "6";     arrayDic["7"] = "7";     arrayDic["8"] = "8";     arrayDic["9"] = "9";     arrayDic["A"] = "10";     arrayDic["B"] = "11";     arrayDic["C"] = "12";     arrayDic["D"] = "13";     arrayDic["E"] = "14";     arrayDic["F"] = "15";     arrayDic["G"] = "16";     arrayDic["H"] = "17";     arrayDic["I"] = "18";     arrayDic["J"] = "19";     arrayDic["K"] = "20";     arrayDic["L"] = "21";     arrayDic["M"] = "22";     arrayDic["N"] = "23";     arrayDic["O"] = "24";     arrayDic["P"] = "25";     arrayDic["Q"] = "26";     arrayDic["R"] = "27";     arrayDic["S"] = "28";     arrayDic["T"] = "29";     arrayDic["U"] = "30";     arrayDic["V"] = "31";     arrayDic["W"] = "32";     arrayDic["X"] = "33";     arrayDic["Y"] = "34";     arrayDic["Z"] = "35";     arrayDic["-"] = "36";     arrayDic["."] = "37";     arrayDic[" "] = "38";     arrayDic["$"] = "39";     arrayDic["/"] = "40";     arrayDic["+"] = "41";     arrayDic["%"] = "42";     arr.map(function (item, i) {         sum += Number(arrayDic[item]);     })     var ys = sum % 43;     if (Number(ys) == Number(arrayDic[code.substr(code.length - 1, 1)]))         return true;     else         return false;

}

function OtherCode_CheckCode(code) {     var arr = code.split("");     var odd = 0, even = 0, num;     arr.map(function (item, i) {         if (i & 1) {

even += Number(item);         } else {

odd += Number(item);         }     })     var codeLen = code.length;     if (codeLen % 2 == 0) {         num = String(10 - Number(String(odd * 3 + even).slice(-1)[0])).slice(-1)[0];     }     else {         num = String(10 - Number(String(odd + even * 3).slice(-1)[0])).slice(-1)[0];     }     return num; }

//从批次码中挑选信息 function GetInfoFromRange(Code, Range) {

if (Range != "") {         var Ranges = Range.split(",");         return Code.substring(parseInt(Ranges[0]) - 1, parseInt(Ranges[1]) + parseInt(Ranges[0]) - 1);     } }

//时间类型字段-截取 function GetDateInfoFromRange(Code, Range) {

if (Range != "") {         var Ranges = Range.split(',');         var dateType = Range.split('|')[1];         return GetDateInformation(Code.substring(parseInt(Ranges[0]) - 1, parseInt(Ranges[1].split('|')[0]) + parseInt(Ranges[0]) - 1), dateType);     } else {         return "";     } } //时间类型字段-截取 function GetDateInfoFromRange(Code, Range) {

if (Range != ""&&Code!="") {         var Ranges = Range.split(',');         var dateType = Range.split('|')[1];         return GetDateInformation(Code.substring(parseInt(Ranges[0]) - 1, parseInt(Ranges[1].split('|')[0]) + parseInt(Ranges[0])), dateType);     } else {         return "";     } }

//根据日期格式格式化日期为要显示日期 //dateString--要格式的日期字条串 如:YYMMDD=>>150928  YYJJJ=>>15182   MMYY==> >1115 //dateType"--格式:如YYMMDD function GetDateInformation(dateString, dateType) {     var myDate = new Date();     var ye = myDate.getFullYear().toString().substring(0, 2);     var result = 0;

switch (dateType) {         case "YYMMDD":             result = ye + dateString.substring(0, 2) + "-" + dateString.substring(2, 4) + "-" + dateString.substring(4, 6);             break;         case "YYJJJ":             var flag = 0;             var year = parseInt(ye + dateString.substring(0, 2));             var Month = 0;             var Days = 0;             var monthIndex = 0;             var day = parseInt(dateString.substring(2, 5));             if ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 100)) flag = 1;             else flag = 0;             var days = [0, 31, 59 + flag, 90 + flag, 120 + flag, 151 + flag, 181 + flag, 212 + flag, 243 + flag, 273 + flag, 304 + flag, 334 + flag, 365 + flag];             for (var i = 0; i < days.length; i++) {                 if (day <= days[i]) {                     Month = i < 10 ? ("0" + i) : i;                     monthIndex = i - 1;                     break;                 }             }             Days = (day - days[monthIndex] < 10) ? "0" + (day - days[monthIndex]) : (day - days[monthIndex]);             result = year + "-" + Month + "-" + Days;             break;         case "MMYY":             year = parseInt(ye + dateString.substring(2, 4));             result = ye + dateString.substring(2, 4) + "-" + dateString.substring(0, 2) + "-01";             break;         case "YYMM":             result = ye + dateString.substring(0, 2) + "-" + dateString.substring(2, 4) + "-01";             break;         default:             break;     }     var nullResult = "";     var matchResult = result.match(/((^((1[8-9]\d{2})|([2-9]\d{3}))(-)(10|12|0?[13578])(-)(3[01]|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(11|0?[469])(-)(30|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(0?2)(-)(2[0-8]|1[0-9]|0?[1-9])$)|(^([2468][048]00)(-)(0?2)(-)(29)$)|(^([3579][26]00)(-)(0?2)(-)(29)$)|(^([1][89][0][48])(-)(0?2)(-)(29)$)|(^([2-9][0-9][0][48])(-)(0?2)(-)(29)$)|(^([1][89][2468][048])(-)(0?2)(-)(29)$)|(^([2-9][0-9][2468][048])(-)(0?2)(-)(29)$)|(^([1][89][13579][26])(-)(0?2)(-)(29)$)|(^([2-9][0-9][13579][26])(-)(0?2)(-)(29)$))/);     if (matchResult==null)         return nullResult;     else         return result;

}

条码解析的一片js的更多相关文章

  1. Ajax实现xml文件数据插入数据库(一)--- 构建解析xml文件的js库

    Ajax实现将xml文件数据插入数据库的过程所涉及到的内容比较多,所以对于该过程的讲解本人打算根据交互的过程将其分为三个部分,第一部分为构建解析xml文件的javascript库,第二部分为ajax与 ...

  2. js字符串转日期,js字符串解析成日期,js日期解析, Date.parse小时是8点,Date.parse时间多了8小时

    js字符串转日期,js字符串解析成日期,js日期解析, Date.parse小时是8点,Date.parse时间多了8小时 >>>>>>>>>&g ...

  3. 不阻塞浏览器的解析,待外部js下载完成后异步执行

    网站统计中的数据收集原理及实现(js埋点实现) - lastwhisper - CSDN博客 https://blog.csdn.net/l1212xiao/article/details/80450 ...

  4. C#调用摄像头(AForge)实现扫描条码解析(Zxing)功能

    网上找了很多代码,都比较零散,以下代码纯自己手写,经过测试.下面有链接,下载后可以直接使用. 介绍: 自动识别:点击Start按钮会调用PC摄像头,代码内置Timer,会每100毫秒识别一下当前摄像头 ...

  5. Vue+Java+Base64实现条码解析

    前端部分(Vue + Vant) 引入Vant.使用Vant中的Uploader组件上传文件(支持手机拍照) import Vue from 'vue'; import { Uploader } fr ...

  6. CSV.js – 用于 CSV 解析和编码的 JS 工具库

    逗号分隔值(CSV )文件用于以以纯文本的形式存储表格化数据(数字和文本). CSV 文件包含任意数量的记录,通过某种换行符分隔,每条记录由字段,其他一些字符或字符串分隔,最常用的是文字逗号或制表符. ...

  7. Java - 字符串和Unicode互转 - 解析小米pm.min.js

    小米JS地址: http://p.www.xiaomi.com/zt/20130313/huodong/pm.min.js 上面这个JS是小米抢手机页面的代码.和抢手机有直接关联.. 虽然我3次都没抢 ...

  8. 利用fastjson解析json并通过js&ajax实现页面的无跳转刷新

    1.json是一种优秀的数据格式,在移动开发和web开发中经常用到,本例中通过一个小案例讲解如何通过alibaba的开源框架fastjson来解析jason数据格式并通过js实现无跳转刷新 2,新建一 ...

  9. 全面解析JavaScript的Backbone.js框架中的Router路由

    这篇文章主要介绍了Backbone.js框架中的Router路由功能,Router在Backbone中相当于一个MVC框架中的Controller控制器功能,需要的朋友可以参考下. Backbone ...

随机推荐

  1. Redis数据库?-Redis的Virtual Memory介绍(转)

    众所周知,Redis是一个内存数据库,和Memcached类似,所有数据存在内存中,当然,Redis有rdb和appendonlyfile两个落地文件,可以对断电停机等故障下的数据恢复做一些保证.但是 ...

  2. 基于List集合映射

    1. 实体类中使用List集合 public class Grade { private int id; private String name; private List<Student> ...

  3. [CSS]如何正确使用ID和Class?

    作者:DarkZone链接:https://www.zhihu.com/question/19550864/answer/23440690来源:知乎 以下摘自<精通CSS:高级Web标准解决方案 ...

  4. 关于maven的一些常见用法

    1: 查看插件的目标信息:mvn help:describe 2: 生成javadoc并指定编码:mvn javadoc:javadoc -Dencoding=UTF-8 -Dcharset=UTF- ...

  5. IP地址查询接口

    新浪的IP地址查询接口:http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js 新浪多地域测试方法:http://int.dpool. ...

  6. 十一、jdk命令之Jstatd命令(Java Statistics Monitoring Daemon)

    目录 一.jdk工具之jps(JVM Process Status Tools)命令使用 二.jdk命令之javah命令(C Header and Stub File Generator) 三.jdk ...

  7. Yii 框架ajax搜索分页

    要想实现ajax搜索分页 其实很简单 第一步:在 Yii 框架自带的搜索和分页正常运行的情况下,在视图层

  8. 如何搭建Struts2环境

    1.解压下载到的struts-2.3.16压缩包. 2.将struts2-blank\WEB-INF\lib 下的jar包复制到Eclipse项目下的libs文件夹下. 3.struts-2.3.16 ...

  9. 第11章 System V 信号量

    11.1 概述 信号量按功能分:二值信号量.计数信号量.信号量集:其中二值信号量和计数信号量指的是Posix信号量,信号量集指的是System V信号量.

  10. 20145305 《Java程序设计》第4周学习总结

    教材学习内容总结 1.子类只能继承一个父类 2.检查多态语法逻辑是否正确,方式是从=号右边往左读:右边是不是一种左边(右边类型是不是左边类型的一种子类) 3.可以使用abstract标示该方法为抽象方 ...