分享我常用的一些JS验证和函数

下面是我常用一些JS验证和函数,有一些验证我直接写到了对象的属性里面了,可以直接通过对象.方法来调用
//浮点数除法运算 function fdiv(a, b, n) { if (n == undefined) { n = 2; } var t1 = 0, t2 = 0, r1, r2; try { t1 = a.toString().split(".")[1].length } catch (e) { } try { t2 = b.toString().split(".")[1].length } catch (e) { } with (Math) { r1 = Number(a.toString().replace(".", "")); r2 = Number(b.toString().replace(".", "")); return ((r1 / r2) * pow(10, t2 - t1)).toFixed(n); } } //浮点数乘法运算 function fmul(a, b, n) { if (n == undefined) { n = 2; } var m = 0, s1 = a.toString(), s2 = b.toString(); try { m += s1.split(".")[1].length } catch (e) { } try { m += s2.split(".")[1].length } catch (e) { } return (Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m)).toFixed(n); } //浮点数加法运算 function fadd(a, b, n) { if (n == undefined) { n = 2; } var r1, r2, m; try { r1 = a.toString().split(".")[1].length } catch (e) { r1 = 0 } try { r2 = b.toString().split(".")[1].length } catch (e) { r2 = 0 } m = Math.pow(10, Math.max(r1, r2)) return ((a * m + b * m) / m).toFixed(n); } //浮点数减法运算 function fsub(a, b, n) { if (n == undefined) { n = 2; } var r1, r2, m; try { r1 = a.toString().split(".")[1].length } catch (e) { r1 = 0 } try { r2 = b.toString().split(".")[1].length } catch (e) { r2 = 0 } m = Math.pow(10, Math.max(r1, r2)); //动态控制精度长度 //n = (r1 >= r2) ? r1 : r2; return ((a * m - b * m) / m).toFixed(n); } Number.prototype.add = function (arg) { return fadd(this, arg); } Number.prototype.subs = function (arg) { return fsub(this, arg); } Number.prototype.mul = function (arg) { return fmul(this, arg); } Number.prototype.div = function (arg) { return fdiv(this, arg); } ///格式化数字位数,不足位数默认左边补0,如果指定了参数2并且参数2的值为1则右边补0 Number.prototype.FormatLen = function (len, direct) { var d = parseInt(direct); if (isNaN(d)) { d = 0; } var num = this.toString(); if (num.length < len) { for (var i = num.length; i < len; i++) { if (d == 0) { num = "0" + num; } else { num += "0"; } } } return num; } //格式化小数点数位,可以指定小数位数,是否四舍五入等参数 Number.prototype.FormatRadix = function (len, IsRound) { var num = this.toString(); var numArr = num.split('.'); var rad = 0; var numpart = parseInt(numArr[0]); if (numArr.length >= 2) { if (numArr[1].length < len) { rad = parseInt(numArr[1]).FormatLen(len, 1); } else { if (numArr[1].length == len) { rad = numArr[1]; } else { rad = numArr[1].substr(0, len); if (IsRound) { var d = parseInt(numArr[1].substr(len, 1)); if (d >= 5) { rad += 1; if (rad.toString().length > len) { numpart += 1; rad = rad.toString().substr(1, len); } } } } } } else { rad = rad.FormatLen(len); } return numpart + "." + rad; } //检测字符串中是否有相同的元素split是字符串分隔符,如果指定了分隔符,则判断分隔符为分隔的字符串是否有重复,如果没指定则判断单个字符串是否有重复 //有重复返回true String.prototype.CompareElement = function (s) { var str = this.toString(); if (s == undefined) { for (var i = 0; i < str.length; i++) { for (j = i + 1; j < str.length; j++) { if (str.substr(i, 1) == str.substr(j, 1)) { return true; } } } } else { var strArr = str.split(s); for (var i = 0; i < strArr.length; i++) { for (var j = i + 1; j < strArr.length; j++) { if (strArr[i] == strArr[j]) { return true; } } } } return false; } String.prototype.replaceAll = function (str, tostr) { oStr = this; while (oStr.indexOf(str) > -1) { oStr = oStr.replace(str, tostr); } return oStr; } Array.prototype.CompareElement = function () { var strArr = this; for (var i = 0; i < strArr.length; i++) { for (var j = i + 1; j < strArr.length; j++) { if (strArr[i] == strArr[j]) { return true; } } } return false; } //字符串转组数,如果未指定分隔符s,则默认以,分隔分隔符,如果指定分隔符为空则将每个字符作为一个数组元素 String.prototype.ToArray = function (s) { if (s == undefined) { s = ","; } var strArr = []; strArr = this.split(s); return strArr; } //将一个数组转换一个字符串,所有元素使用指定的分隔符连接,默认分隔为, Array.prototype.ToIDList = function (s) { if (s == undefined) { s = ","; } var list = ""; for (var i = 0; i < this.length; i++) { list += (list == "" ? this[i] : s + "" + this[i]); } return list; } //获取指定元素的位置索引,元素不存在返回-1 Array.prototype.GetIndex = function (s) { var index = -1; for (var i = 0; i < this.length; i++) { if ((s + "") == this[i]) { index = i; } } return index; } //将指定元素从数组中删除 Array.prototype.Remove = function (s) { var list = ""; for (var i = 0; i < this.length; i++) { if (s != this[i]) { list += (list == "" ? this[i] : "," + this[i]); } } return list.ToArray(); } ///将数组进行数字排序asc指定是否进行升序排序,可以为true或者false,未指定为升序 Array.prototype.SortByNumber = function (asc) { if (asc == undefined) { asc = true; } if (asc) { return this.sort(SortNumberAsc); } else { return this.sort(SortNumberDesc); } } Array.prototype.InArray = function (e) { var IsIn = false; for (var i = 0; i < this.length; i++) { if (this[i] == (e + "")) { IsIn = true; } } return IsIn; } String.prototype.Trim = function (s) { return Trim(this, s); } String.prototype.LTrim = function (s) { return LTrim(this, s); } String.prototype.RTrim = function (s) { return RTrim(this, s); } //配合Array.SortByNumer使用,将数字进行数组降序排序 function SortNumberDesc(a, b) { return b - a; } //配合Array.SortByNumer使用,将数字进行数组升序排序 function SortNumberAsc(a, b) { return a - b; } //此处为独立函数 function LTrim(str, s) { if (s == undefined) { s = " "; } if (str == s && s != " ") { return s; } var i; for (i = 0; i < str.length; i++) { if (str.charAt(i) != s && str.charAt(i) != s) break; } str = str.substring(i, str.length); return str; } function RTrim(str, s) { var i; if (str == s && s != " ") { return s; } if (s == undefined) { s = " "; } for (i = str.length - 1; i >= 0; i--) { if (str.charAt(i) != s && str.charAt(i) != s) break; } str = str.substring(0, i + 1); return str; } function Trim(str, s) { return LTrim(RTrim(str, s), s); } ///检测字符串是否是由中文,英文,数字以及下划线组成的 function chkNickName(str) { var pattern = /^[\w\u4e00-\u9fa5]+$/gi; if (pattern.test(str)) { return true; } return false; } //判断长度(长度不限为0) String.prototype.IsLen = function () { var isRightFormat = false; var minnum = arguments[0] ? arguments[0] : 0; var maxnum = arguments[1] ? arguments[1] : 0; isRightFormat = (minnum == 0 && maxnum == 0 ? true : (calculate_byte(this) >= minnum && calculate_byte(this) \"\"])*$/; if (myReg.test(this)) return true; return false; } //验证域名 String.prototype.IsDoMainName = function () { var myReg = /^[0-9a-zA-Z]([0-9a-zA-Z\-]+\.){1,3}[a-zA-Z]{2,4}?$/; if (myReg.test(this)) return true; return false; } //验证IPV4地址 String.prototype.IsIpv4 = function () { var myReg = /^(2[0-5]{2}|1?[0-9]{1,2}).(2[0-5]{2}|1?[0-9]{1,2}).(2[0-5]{2}|1?[0-9]{1,2}).(2[0-5]{2}|1?[0-9]{1,2})$/; if (myReg.test(this)) return true; return false; } //验证图片地址(不支持由CGI动态生成的图片) String.prototype.IsImgURL = function () { var myReg = /^\.(jpeg|jpg|gif|bmp|png|pcx|tiff|tga|lwf)$/; if (myReg.test(this)) return true; return false; } //验证手机号码 String.prototype.IsCellPhone = function () { var myReg = /^((\(\d{3}\))|(\d{3}\-))?1[3,5]\d{9}$/; if (myReg.test(this)) return true; return false; } //验证固定电话 String.prototype.IsPhone = function () { var myReg = /^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/; if (myReg.test(this)) return true; return false; } //验证邮编 String.prototype.IsZipCode = function () { var myReg = /[0-9]{6}/; if (myReg.test(this)) return true; return false; } //验证身份证号码 String.prototype.IsIdCard = function () { var myReg = /(^([\d]{15}|[\d]{18}|[\d]{17}[xX]{1})$)/; if (myReg.test(this)) return true; return false; } //验证日期格式YY-MM-DD String.prototype.IsDateFormat = function () { var myReg = /^[0-9]{4}-[0-9]{1,2}-[0-9]{1,2}$/; if (myReg.test(this)) return true; return false; } //验证时间格式HH:MM:SS String.prototype.IsRangeTime = function () { var myReg = /^(\d{2}):(\d{2}):(\d{2})$/; if (myReg.test(this)) return true; return false; } //验证金额格式 String.prototype.IsMoney = function () { var myReg = /^[0-9]{1,8}[.]{0,1}[0-9]{0,6}$/; if (myReg.test(this)) return true; return false; } //字验证数字格式并判断数字的围(min:最小值;max:最大值.) String.prototype.IsInt = function () { var isRightFormat = false; var minnum = arguments[0] ? arguments[0] : 0; var maxnum = arguments[1] ? arguments[1] : 0; var myReg = /^[-\+]?\d+$/; if (myReg.test(this)) { isRightFormat = (minnum == 0 && maxnum == 0 ? true : (this > minnum && this < maxnum ? true : false)); } return isRightFormat; } //验证搜索关键字 String.prototype.IsSearch = function () { var myReg = /^[\|\"\'<>,.*&@#$;:!^()]/; if (myReg.test(this)) return false; return true; } //js准确计算字符串长度 function calculate_byte(sTargetStr) { var sTmpStr, sTmpChar; var nOriginLen = 0; var nStrLength = 0; sTmpStr = new String(sTargetStr); nOriginLen = sTmpStr.length; for (var i = 0; i < nOriginLen; i++) { sTmpChar = sTmpStr.charAt(i); if (escape(sTmpChar).length > 4) { nStrLength += 2; } else if (sTmpChar != '\r') { nStrLength++; } } return nStrLength; } //颜色值; String.prototype.IsColor = function () { var s = arguments[0] ? arguments[0] : ""; s = s.Trim(); if (s.length != 7) return false; return s.search(/\#[a-fA-F0-9]{6}/) != -1; } //js日期格式化 Date.prototype.format = function (format) { var o = { "M+": this.getMonth() + 1, //month "d+": this.getDate(), //day "h+": this.getHours(), //hour "m+": this.getMinutes(), //minute "s+": this.getSeconds(), //second "q+": Math.floor((this.getMonth() + 3) / 3), //quarter "S": this.getMilliseconds() //millisecond } if (/(y+)/.test(format)) { format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length)); } for (var k in o) { if (new RegExp("(" + k + ")").test(format)) { format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length)); } } return format; } function HasChinese(value) { if (/^[\u4e00-\u9fa5]+$/.test(value)) { return true; } return false; } function ToDate(dateStr) { var dStr = dateStr.toString(); dateStr = dStr.replaceAll("-", "/"); return new Date(Date.parse(dateStr)); } //是否ID列表 String.prototype.IsIdList = function (s) { if (s == undefined) { s = ","; } var arr = this.split(s); for (var i = 0; i < arr.length; i++) { if (isNaN(parseInt(arr[i]))) { return false; } } return true; } //获取事件触发的对象 function getEventTarget(e) { e = e || window.event; return e.target || e.srcElement; }

Original: https://www.cnblogs.com/ithome8/p/4117911.html
Author: IT之家
Title: 分享我常用的一些JS验证和函数

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/591834/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • Zookeeper应用场景汇总(超详细)

    Zookeeper典型应用场景汇总 数据发布与订阅(配置中心) 发布与订阅模型,即所谓的配置中心,顾名思义就是发布者将数据发布到ZK节点上,供订阅者动态获取数据,实现配置信息的集中…

    数据库 2023年6月11日
    088
  • django-ckeditor配置html5video上传视频

    参考信息 为Django ckeditor配置上传视频:https://www.byincd.com/bobjiang/article-01128/ 使用 1. 手动下载插件 ht…

    数据库 2023年6月9日
    094
  • (面试)大型网站应用之海量数据、高并发解决方案

    面试时会遇到这样的提问,就记录下来,加深印象;以后工作中也可以用到。 海量数据的解决方案: 网站访问数据的特点大多数呈现为”二八定律”:80%的业务访问集中…

    数据库 2023年6月11日
    055
  • Python丨听说这个地方的漫画不错,只用40行代码,给它全部爬下来

    前因后果 公司新来的小姐姐,超级喜欢看漫画,天天给我介绍,好烦~ 现在是2022年9月15日16点30,于是我决定, 五点下班前写个代码把她说的漫画全部爬下来,应付一下~ 再发篇文…

    数据库 2023年6月14日
    0120
  • MySQL特性:BKA,Batched Key Access,批量索引访问

    Nested Loop Join → Block Nested-Loop Join → Batched Key Access表Join时使用BNL/BKA,需要temporary。…

    数据库 2023年6月16日
    0106
  • ShardingSphere-JDBC进行分库分表

    一、前言:分库分表 在大型的互联网系统中,可能单台MySQL的存储容量无法满足业务的需求,这时候就需要进行扩容了。 和之前的问题一样,单台主机的硬件资源是存在瓶颈的,不可能无限制地…

    数据库 2023年6月14日
    073
  • 「萌新指南」SOA vs. 微服务:What’s the Difference?

    实话实说,在我还没有实习之前,我是连 SOA 是啥都不知道的,只听说过微服务,毕竟微服务实在太火了,想不知道都难,我觉得实习的时候肯定也是微服务,进组之后发现是 SOA 架构,当时…

    数据库 2023年6月6日
    0112
  • 数据中有emoji,导致插入不了数据库

    前言 前两天负责的系统,因为需要获取用户的昵称并进行入库,但是有个别用户的昵称中存在emoji表情,导致入库时报错。 报错内容: java.sql.SQLException: In…

    数据库 2023年5月24日
    0123
  • Linux 守护进程

    1. 守护进程是什么 2. 怎么用守护进程 2.1 有趣小例子 2.2 man daemon 3. 源码解析 3.1 GUN C daemon.c 3.2 daemon.c 解析 …

    数据库 2023年6月9日
    077
  • 0811JDBC随笔

    1.JDBC体系系统 一组规范:接口 JDBC接口(API)包括两个层次: 面向应用的API:Java API,抽象接口,供应用开发人员使用(连接数据库,执行SQL语句,获得结果)…

    数据库 2023年5月24日
    074
  • JVM内存结构–新生代及新生代里的两个Survivor区(下一轮S0与S1交换角色,如此循环往复)、常见调优参数

    一、为什么会有年轻代 我们先来屡屡,为什么需要把堆分代?不分代不能完成他所做的事情么?其实不分代完全可以,分代的唯一理由就是优化GC性能。你先想想,如果没有分代,那我们所有的对象都…

    数据库 2023年6月16日
    0115
  • java面试题总结

    1,集合类面试题 arraylist和linkedlist的区别?底层实现?手写实现?线程安全吗以及原因? hashmap的底层实现?put()执行过程?put null时的执行过…

    数据库 2023年6月11日
    091
  • Node.js安装

    nvm NVM: Node Version Manager 下载地址 Mac/Linux安装 nvm:https://github.com/nvm-sh/nvm Windows 安…

    数据库 2023年6月6日
    093
  • 线程的同步

    线程同步机制同步块:Java中提供了同步机制,可以有效的防止资源冲突。同步机制使用 synchronized关键字 使用该关键字的代码块称为同步块。同步块 语法: synchron…

    数据库 2023年6月16日
    0127
  • MySQL45讲之InnoDB刷脏策略

    本文介绍 InnoDB 的刷脏控制策略,它是如何控制刷脏速率的,以及一些相关参数。 了解 MySQL 的刷脏策略有什么意义? 当一条正确的 SQL 执行时偶尔延迟较高,无法复现场景…

    数据库 2023年5月24日
    085
  • [javaweb]重点总结大全

    javaweb web:网页静态web:html,css 数据不会发生变化动态web:servlet/jsp,asp,php每个人在不同的时间看到数据都不同 web应用程序编写完毕…

    数据库 2023年6月16日
    083
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球