`
zyn_cool
  • 浏览: 27604 次
  • 性别: Icon_minigender_2
  • 来自: 济南
最近访客 更多访客>>
社区版块
存档分类
最新评论

javascript中常用的验证(摘)

阅读更多
从网上看到这些js验证写的挺好的摘下来以后用,非常感谢这篇文章的作者


JS 验证
/**
* js 各种表单数据验证
*/
/**************************************************************************************/
/*************************************数字的验 证*****************************************/
/**************************************************************************************/

/**
* 检查输入的一串字符是否全部是数字
* 输入:str 字符 串
* 返回:true 或 flase; true表示为数字
*/
function checkNum(str){
return str.match(/\D/) == null;
}

/**
* 检查输入的一串字符是否为小数
* 输入:str 字符串
* 返 回:true 或 flase; true表示为小数
*/
function checkDecimal(str){
if (str.match(/^-?\d+(\.\d+)?$/g) == null) {
return false;
}
else {
return true;
}
}

/**
* 检查输入的一串字符是否为整型数据
* 输入:str 字 符串
* 返回:true 或 flase; true表示为小数
*/
function checkInteger(str){
if (str.match(/^[-+]?\d*$/) == null) {
return false;
}
else {
return true;
}
}

/**************************************************************************************/
/*************************************字符的验 证*****************************************/
/**************************************************************************************/

/**
* 检查输入的一串字符是否是字符
* 输入:str 字符串
* 返 回:true 或 flase; true表示为全部为字符 不包含汉字
*/
function checkStr(str){
if (/[^\x00-\xff]/g.test(str)) {
return false;
}
else {
return true;
}
}

/**
* 检查输入的一串字符是否包含汉字
* 输入:str 字符串
* 返 回:true 或 flase; true表示包含汉字
*/
function checkChinese(str){
if (escape(str).indexOf(“%u”) != -1) {
return true;
}
else {
return false;
}
}

/**
* 检查输入的邮箱格式是否正确
* 输入:str 字符串
* 返 回:true 或 flase; true表示格式正确
*/
function checkEmail(str){
if (str.match(/[A-Za-z0-9_-]+[@](\S*)(net|com|cn|org|cc|tv|[0-9]{1,3})(\S*)/g) == null) {
return false;
}
else {
return true;
}
}

/**
* 检查输入的手机号码格式是否 正确
* 输入:str 字符串
* 返回:true 或 flase; true表示格式正确
*/
function checkMobilePhone(str){
if (str.match(/^(?:13\d|15[89])-?\d{5}(\d{3}|\*{3})$/) == null) {
return false;
}
else {
return true;
}
}

/**
* 检查输入的固定电话号码是否 正确
* 输入:str 字符串
* 返回:true 或 flase; true表示格式正确
*/
function checkTelephone(str){
if (str.match(/^(([0\+]\d{2,3}-)?(0\d{2,3})-)(\d{7,8})(-(\d{3,}))?$/) == null) {
return false;
}
else {
return true;
}
}

/**
* 检查QQ的格式是否正确
* 输入:str 字符串
* 返 回:true 或 flase; true表示格式正确
*/
function checkQQ(str){
if (str.match(/^\d{5,10}$/) == null) {
return false;
}
else {
return true;
}
}

/**
* 检查输入的身份证号是否正确
* 输入:str 字符串
* 返 回:true 或 flase; true表示格式正确
*/
function checkCard(str){
//15位数身份证正则表达式
var arg1 = /^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;
//18位数身份证正则表达式
var arg2 = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[A-Z])$/;
if (str.match(arg1) == null && str.match(arg2) == null) {
return false;
}
else {
return true;
}
}

/**
* 检查输入的IP地址是否正确
* 输入:str 字符串
* 返 回:true 或 flase; true表示格式正确
*/
function checkIP(str){
var arg = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/;
if (str.match(arg) == null) {
return false;
}
else {
return true;
}
}

/**
* 检查输入的URL地址是否正确
* 输入:str 字符串
* 返 回:true 或 flase; true表示格式正确
*/
function checkURL(str){
if (str.match(/(http[s]?|ftp):\/\/[^\/\.]+?\..+\w$/i) == null) {
return false
}
else {
return true;
}
}

/**
* 检查输入的字符是否具有特殊字符
* 输入:str 字符串
* 返 回:true 或 flase; true表示包含特殊字符
* 主要用于注册信息的时候验证
*/
function checkQuote(str){
var items = new Array(“~”, “`”, “!”, “@”, “#”, “$”, “%”, “^”, “&”, “*”, “{“, “}”, “[", "]“, “(“, “)”);
items.push(“:”, “;”, “‘”, “|”, “\\”, “<”, “>”, “?”, “/”, “<<”, “>>”, “||”, “//”);
items.push(“admin”, “administrators”, “administrator”, “管 理员”, “系统管理员”);
items.push(“select”, “delete”, “update”, “insert”, “create”, “drop”, “alter”, “trancate”);
str = str.toLowerCase();
for (var i = 0; i < items.length; i++) {
if (str.indexOf(items[i]) >= 0) {
return true;
}
}
return false;
}

/**************************************************************************************/
/*************************************时间的验 证*****************************************/
/**************************************************************************************/

/**
* 检查日期格式是否正确
* 输入:str 字符串
* 返 回:true 或 flase; true表示格式正确
* 注意:此处不能验证中文日期格式
* 验证短日期(2007-06-05)
*/
function checkDate(str){
//var value=str.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)$))/);
var value = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
if (value == null) {
return false;
}
else {
var date = new Date(value[1], value[3] – 1, value[4]);
return (date.getFullYear() == value[1] && (date.getMonth() + 1) == value[3] && date.getDate() == value[4]);
}
}

/**
* 检查时间格式是否正确
* 输入:str 字符串
* 返回:true 或 flase; true表示 格式正确
* 验证时间(10:57:10)
*/
function checkTime(str){
var value = str.match(/^(\d{1,2})(:)?(\d{1,2})\2(\d{1,2})$/)
if (value == null) {
return false;
}
else {
if (value[1] > 24 || value[3] > 60 || value[4] > 60) {
return false
}
else {
return true;
}
}
}

/**
* 检查全日期时间格式是否正确
* 输入:str 字符串
* 返 回:true 或 flase; true表示格式正确
* (2007-06-05 10:57:10)
*/
function checkFullTime(str){
//var value = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/);
var value = str.match(/^(?:19|20)[0-9][0-9]-(?:(?:0[1-9])|(?:1[0-2]))-(?:(?:[0-2][1-9])|(?:[1-3][0-1])) (?:(?:[0-2][0-3])|(?:[0-1][0-9])):[0-5][0-9]:[0-5][0-9]$/);
if (value == null) {
return false;
}
else {
//var date = new Date(checkFullTime[1], checkFullTime[3] – 1, checkFullTime[4], checkFullTime[5], checkFullTime[6], checkFullTime[7]);
//return (date.getFullYear() == value[1] && (date.getMonth() + 1) == value[3] && date.getDate() == value[4] && date.getHours() == value[5] && date.getMinutes() == value[6] && date.getSeconds() == value[7]);
return true;
}

}

/**************************************************************************************/
/************************************身份证号码的 验证*************************************/
/**************************************************************************************/

/**
* 身份证15位编码规则:dddddd yymmdd xx p
* dddddd: 地区码
* yymmdd: 出生年月日
* xx: 顺序类编码,无法确定
* p: 性别,奇数为男,偶数为女
* <p />
* 身 份证18位编码规则:dddddd yyyymmdd xxx y
* dddddd:地区码
* yyyymmdd: 出生年月日
* xxx: 顺序类编码,无法确定,奇数为男,偶数为女
* y: 校验码,该位数值可通过前17位计算获得
* <p />
* 18 位号码加权因子为(从右到 左) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ]
* 验 证位 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]
* 校验位计算公 式:Y_P = mod( ∑(Ai×Wi),11 )
* i为身份证号码从右往左数的 2…18 位; Y_P为脚丫校验码所在校验码数 组位置
*
*/
var Wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1];// 加权因子
var ValideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2];// 身份证验证位值.10代表X
function IdCardValidate(idCard){
idCard = trim(idCard.replace(/ /g, “”));
if (idCard.length == 15) {
return isValidityBrithBy15IdCard(idCard);
}
else
if (idCard.length == 18) {
var a_idCard = idCard.split(“”);// 得到身份证数组
if (isValidityBrithBy18IdCard(idCard) && isTrueValidateCodeBy18IdCard(a_idCard)) {
return true;
}
else {
return false;
}
}
else {
return false;
}
}

/**
* 判断身份证号码为18位时最后的验证位是否正确
* @param a_idCard 身份证号码数组
* @return
*/
function isTrueValidateCodeBy18IdCard(a_idCard){
var sum = 0; // 声明加权求和变量
if (a_idCard[17].toLowerCase() == ‘x’) {
a_idCard[17] = 10;// 将最后位为x的验证码替换为10方便后续操作
}
for (var i = 0; i < 17; i++) {
sum += Wi[i] * a_idCard[i];// 加权求和
}
valCodePosition = sum % 11;// 得到验证码所位置
if (a_idCard[17] == ValideCode[valCodePosition]) {
return true;
}
else {
return false;
}
}

/**
* 通过身份证判断是男是女
* @param idCard 15/18位身份证号码
* @return ‘female’- 女、’male’-男
*/
function maleOrFemalByIdCard(idCard){
idCard = trim(idCard.replace(/ /g, “”));// 对身份证号码做处理。包括字符间有空格。
if (idCard.length == 15) {
if (idCard.substring(14, 15) % 2 == 0) {
return ‘female’;
}
else {
return ‘male’;
}
}
else
if (idCard.length == 18) {
if (idCard.substring(14, 17) % 2 == 0) {
return ‘female’;
}
else {
return ‘male’;
}
}
else {
return null;
}
}

/**
* 验证18位数身份证号码中的生日是否是有效生日
* @param idCard 18位书身份证字符串
* @return
*/
function isValidityBrithBy18IdCard(idCard18){
var year = idCard18.substring(6, 10);
var month = idCard18.substring(10, 12);
var day = idCard18.substring(12, 14);
var temp_date = new Date(year, parseFloat(month) – 1, parseFloat(day));
// 这里用getFullYear()获取年份,避免千年虫问题
if (temp_date.getFullYear() != parseFloat(year) ||
temp_date.getMonth() != parseFloat(month) – 1 ||
temp_date.getDate() != parseFloat(day)) {
return false;
}
else {
return true;
}
}

/**
* 验证15位数身份证号码中的生日是否是有效生日
* @param idCard15 15位书身份证字符串
* @return
*/
function isValidityBrithBy15IdCard(idCard15){
var year = idCard15.substring(6, 8);
var month = idCard15.substring(8, 10);
var day = idCard15.substring(10, 12);
var temp_date = new Date(year, parseFloat(month) – 1, parseFloat(day));
// 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法
if (temp_date.getYear() != parseFloat(year) ||
temp_date.getMonth() != parseFloat(month) – 1 ||
temp_date.getDate() != parseFloat(day)) {
return false;
}
else {
return true;
}
}

/**去掉字符串头尾空格*/
function trim(str){
return str.replace(/(^\s*)|(\s*$)/g, “”);
}

分享到:
评论
1 楼 nigelzeng 2011-10-18  
谢谢分享~

相关推荐

    javascript常用验证方法

    根据提供的文件信息,我们可以总结出一系列关于JavaScript中常用的验证方法的知识点。这些验证方法主要针对电话号码、邮政编码、身份证号码、手机号码以及电子邮件地址等常见的数据格式进行有效性检查。 ### 1. ...

    基于JavaScript的表单验证.zip

    在实践过程中,常见的验证方法包括非空验证、长度验证、格式验证等。例如,手机号码通常要求11位数字,邮箱需要包含'@'和'.'等。JavaScript还可以结合`prompt`或`alert`函数向用户显示提示信息,或者动态修改元素的...

    javascript之validate验证脚本

    JavaScript是Web开发中不可或缺的一部分,尤其在前端领域,它承担着与用户交互、数据验证的重要职责。Validate验证脚本就是JavaScript实现的一种表单验证技术,用于确保用户输入的数据符合预设的规则,防止无效或...

    JavaScript客户端输入验证

    JavaScript客户端输入验证是Web开发中不可或缺的一环,它主要用于在用户提交数据到服务器之前检查数据的有效性和格式。这种验证可以防止无效数据的提交,减轻服务器的负担,提高用户体验,因为错误提示可以即时显示...

    JavaScript验证用户登录

    JavaScript验证用户登录 JavaScript验证用户登录 JavaScript验证用户登录

    javascript表单验证 正则表达式验证表单

    比较实用的javascript做的表单验证,验证的表单域包括用户名、密码、密码...表单域基本通过获得焦点显示提示信息,失去焦点进行验证,还有提交表单验证。提交表单先进行必填项不能为空验证,再进行正则表达式匹配验证。

    javascript 表单验证禁止输入中文汉字

    JavaScript 是一种常用的客户端脚本语言,它可以直接在用户的浏览器上运行,用于实现表单验证。在这个场景中,我们需要实现的功能是:在JavaScript中禁止用户在表单字段中输入中文汉字。 首先,我们要理解如何检测...

    JavaScript表单常用验证集合_应用技巧

    ### JavaScript表单常用验证集合:应用技巧 在Web开发中,表单验证是确保用户输入数据有效性和安全性的重要环节。JavaScript作为前端开发的核心语言之一,提供了丰富的工具来实现这一目标。本文将详细介绍几种常见...

    JavaScript客户端验证和页面特效制作(JavaScript)

    在实际应用中,了解和掌握常见的JavaScript库和框架,如jQuery、React或Vue.js,将大大提升你的开发效率。它们封装了许多复杂的功能,如动画效果、组件化开发、状态管理等,使开发者能更专注于业务逻辑,而不是底层...

    javascript验证日期格式

    其中,日期格式验证是JavaScript中一个常见且实用的功能,它可以帮助开发者确保用户输入的日期符合预设的格式,从而避免数据处理中的错误。本文将深入探讨如何使用JavaScript来验证日期格式,理解其工作原理,并分析...

    JAVASCRIPT常用格式验证 数据安全验证之正则表达式 大全.rar

    本资源"JAVASCRIPT常用格式验证 数据安全验证之正则表达式大全"显然是一个集合了JavaScript中各种常见格式验证的正则表达式库,对于开发者来说是非常实用的参考资料。 正则表达式在JavaScript中的应用非常广泛,...

    javascript常用语句 js简单验证 js

    综上所述,JavaScript的常用语句和简单验证在网页开发中扮演着至关重要的角色。它们帮助确保了用户输入的有效性和安全性,同时也提升了网站的用户体验。通过学习和熟练掌握这些技巧,开发者能够构建更健壮、更用户...

    使用JavaScript语言进行表单验证

    下面将介绍几种常见表单区域的验证方法,包括如何确保某个区域已填写、电子邮件地址格式正确以及密码强度检查。 ##### 1. 确保某个区域已填写 对于某些表单字段,比如用户名、密码等,通常要求用户必须填写。以下...

    JavaScript表单验证控制代码大全

    JavaScript是Web开发中不可或缺的一部分,尤其在前端交互和用户数据验证方面起着至关重要的作用。"JavaScript表单验证控制代码大全"是一个集成了多种表单验证技术和策略的资源集合,帮助开发者有效地确保用户输入的...

    用javascript对表单进行验证

    在 JavaScript 中,可以使用正则表达式来验证手机号码的格式。例如,以下代码用于验证手机号码是否合法: ``` function check(){ var code=document.getElementById("mobilecode").value; var re=/^(130|131|133|...

    JavaScript验证——邮箱验证

    其中,邮箱验证是非常常见且重要的一个环节。通过JavaScript来实现邮箱验证不仅可以提升用户体验,还能增强系统的安全性。 #### 二、核心知识点解析 ##### 2.1 邮箱格式规范 根据互联网标准,一个有效的电子邮件...

    javascript验证框架

    在JavaScript验证框架中,有以下几个重要的知识点: 1. **验证规则**:验证框架通常定义了一系列内置的验证规则,如非空、长度限制、格式匹配(例如邮箱、电话号码)等。开发者可以根据需求选择或自定义规则,以...

    身份验证JavaScript

    在JSP(JavaServer Pages)页面中,JavaScript可以用来辅助进行初步的身份验证,比如身份证号码(ID Card)的验证,这是【标题】"身份验证JavaScript"所涉及的主要内容。而【描述】提到的"jsp页面中的身份的验证...

    JavaScript客户端验证和页面特效制作.jar

    在"JavaScript客户端验证和页面特效制作.jar"这个资源中,我们可以推测它可能包含了一系列关于JavaScript学习的章节或教程,尤其是侧重于这两方面的内容。"chapter1"可能是系列教程的第一部分,可能涵盖了基础的...

Global site tag (gtag.js) - Google Analytics