常用的JS验证和函数汇总


Posted in Javascript onDecember 23, 2014

下面是我常用一些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) <= maxnum ? true : false));

    return isRightFormat;

}
//验证字符串是否为字母+数字+_+-

String.prototype.IsStr = function () {

    var myReg = /^[0-9a-zA-Z\-\_]+$/;

    if (myReg.test(this)) return true;

    return false;

}
//验证用户名

String.prototype.IsUsername = function () {

    var myReg = /^[0-9a-zA-Z\-\_]{3,50}$/;

    if (myReg.test(this)) return true;

    return false;

}
//验证密码

String.prototype.IsPassword = function () {

    var myReg = /^[0-9a-zA-Z`~!@#$%^&*()-_+=\{\}\[\]\;\:\"\'\?\/\\]{6,}$/;

    if (myReg.test(this)) return true;

    return false;

}
//验证是否为字母

String.prototype.IsEn = function () {

    var myReg = /^[a-zA-Z]+$/;

    if (myReg.test(this)) return true;

    return false;

}
//验证是否为汉字

String.prototype.IsCn = function () {

    var myReg = /^[\u0391-\uFFE5]+$/;

    if (myReg.test(this)) return true;

    return false;

}
//验证E-mail

String.prototype.IsEmail = function () {

    var myReg = /([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)/;

    if (myReg.test(this)) return true;

    return false;

}
//验证MSN

String.prototype.IsMSN = function () {

    var myReg = /([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)/;

    if (myReg.test(this)) return true;

    return false;

}
//验证QQ号码

String.prototype.IsQQ = function () {

    var myReg = /^[1-9]\d{4,10}$/;

    if (myReg.test(this)) return true;

    return false;

}
//验证网址

String.prototype.IsHttpUrl = function () {

    var myReg = /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/;

    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;

} 

代码都很简洁,简单,功能却都很实用,有需要的小伙伴参考下

Javascript 相关文章推荐
jQuery 1.5 源码解读 面向中高阶JSER
Apr 05 Javascript
jsonp跨域请求数据实现手机号码查询实例分析
Dec 12 Javascript
jQuery滚动加载图片实现原理
Dec 14 Javascript
用原生js统计文本行数的简单示例
Aug 19 Javascript
a标签跳转到指定div,jquery添加和移除class属性的实现方法
Oct 10 Javascript
JavaScript注入漏洞的原理及防范(详解)
Dec 04 Javascript
微信小程序实战之自定义抽屉菜单(7)
Apr 18 Javascript
JS实现移动端判断上拉和下滑功能
Aug 07 Javascript
p5.js入门教程之平滑过渡(Easing)
Mar 16 Javascript
React Router v4 入坑指南(小结)
Apr 08 Javascript
从0到1搭建Element的后台框架的方法步骤
Apr 10 Javascript
深入理解Antd-Select组件的用法
Feb 25 Javascript
jQuery后代选择器用法实例
Dec 23 #Javascript
浅析Javascript中“==”与“===”的区别
Dec 23 #Javascript
javascript实现微信分享
Dec 23 #Javascript
JSON取值前判断
Dec 23 #Javascript
jQuery基础语法实例入门
Dec 23 #Javascript
jQuery回调函数的定义及用法实例
Dec 23 #Javascript
jQuery中odd选择器的定义和用法
Dec 23 #Javascript
You might like
国王的咖啡这么大来头,名字的由来是什么
2021/03/03 咖啡文化
利用js调用后台php进行数据处理原码
2006/10/09 PHP
中篇:安装及配置PHP
2006/12/13 PHP
php析构函数的简单使用说明
2015/08/24 PHP
TP5.0框架实现无限极回复功能的方法分析
2019/05/04 PHP
PHP实现创建一个RPC服务操作示例
2020/02/23 PHP
JavaScript游戏之是男人就下100层代码打包
2010/11/08 Javascript
javascript的函数、创建对象、封装、属性和方法、继承
2011/03/10 Javascript
window.returnValue使用方法示例介绍
2014/07/03 Javascript
谈一谈javascript中继承的多种方式
2016/02/19 Javascript
Bootstrap每天必学之滚动监听
2016/03/16 Javascript
javascript操作cookie
2017/01/17 Javascript
jQuery图片轮播功能实例代码
2017/01/29 Javascript
jquery获取select,option所有的value和text的实例
2017/03/06 Javascript
基于vue2.0实现仿百度前端分页效果附实现代码
2018/10/30 Javascript
在Vue项目中使用jsencrypt.js对数据进行加密传输的方法
2019/04/17 Javascript
微信小程序导航栏跟随滑动效果的实现代码
2019/05/14 Javascript
JS中比较两个Object数组是否相等方法实例
2019/11/11 Javascript
微信小程序去除左上角返回键的实现方法
2020/03/06 Javascript
JavaScript中数组去重的5种方法
2020/07/04 Javascript
JavaScript动画实例之粒子文本的实现方法详解
2020/07/28 Javascript
[01:19:35]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第二局
2016/03/05 DOTA
[01:02:48]2018DOTA2亚洲邀请赛 4.1 小组赛 A组 LGD vs OG
2018/04/02 DOTA
python安装与使用redis的方法
2016/04/19 Python
Python第三方库face_recognition在windows上的安装过程
2019/05/03 Python
python安装numpy和pandas的方法步骤
2019/05/27 Python
对Django 转发和重定向的实例详解
2019/08/06 Python
python实现超市管理系统(后台管理)
2019/10/25 Python
如何填写个人简历自我评价
2013/12/10 职场文书
学校后勤人员职责
2013/12/27 职场文书
2014年检验科工作总结
2014/11/22 职场文书
2014年行政人事工作总结
2014/12/09 职场文书
居委会工作总结2015
2015/05/18 职场文书
公司2015年终工作总结
2015/05/26 职场文书
如何书写民事调解协议书?
2019/06/25 职场文书
golang通过递归遍历生成树状结构的操作
2021/04/28 Golang