⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 validation.js

📁 ShopEx网店系统是一款免费的独立网店系统
💻 JS
字号:
/*
* Really easy field validation with Prototype
* http://tetlaw.id.au/view/javascript/really-easy-field-validation
* Andrew Tetlaw
* Version 1.5.4.1 (2007-01-05)
* 
* Copyright (c) 2007 Andrew Tetlaw
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use, copy,
* modify, merge, publish, distribute, sublicense, and/or sell copies
* of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
* 
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
* 
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
* 
*/
var Validator = Class.create();

Validator.prototype = {
	initialize : function(className, error, test, options) {
		if (typeof test == 'function') {
			this.options = $H(options);
			this._test = test;
		} else {
			this.options = $H(test);
			this._test = function(){return true};
		}
		this.error = error || 'Validation failed.';
		this.className = className;
	},
	test : function(v, elm) {
		return (this._test(v,elm) && this.options.all(
			function(p){
				return Validator.methods[p.key] ? Validator.methods[p.key](v,elm,p.value) : true;
			}
		));
	}
}
Validator.methods = {
	pattern : function(v,elm,opt) {
		return Validation.get('IsEmpty').test(v) || opt.test(v)
	},
	minLength : function(v,elm,opt) {
		return v.length >= opt
	},
	maxLength : function(v,elm,opt) {
		return v.length <= opt
	},
	min : function(v,elm,opt) {
		return v >= parseFloat(opt)
	}, 
	max : function(v,elm,opt) {return v <= parseFloat(opt)},
	notOneOf : function(v,elm,opt) {return $A(opt).all(function(value) {
		return v != value;
	})},
	oneOf : function(v,elm,opt) {return $A(opt).any(function(value) {
		return v == value;
	})},
	is : function(v,elm,opt) {return v == opt},
	isNot : function(v,elm,opt) {return v != opt},
	equalToField : function(v,elm,opt) {return v == $F(opt)},
	notEqualToField : function(v,elm,opt) {return v != $F(opt)},
	include : function(v,elm,opt) {return $A(opt).all(function(value) {
		return Validation.get(value).test(v,elm);
	})}
}

var Validation = Class.create();

Validation.prototype = {
	initialize : function(form, options) {
		this.options = Object.extend(
			{
				onSubmit : true,
				stopOnFirst : false,
				immediate : false,
				focusOnError : true,
				useTitles : false,
				onFormValidate : function(result, form) {},
				onElementValidate : function(result, elm) {}
			},
			options || {}
		);
		this.form = form;
		if(this.options.onSubmit) {
			Event.observe(this.form, 'submit', this.onSubmit.bind(this), false);
		}
		if(this.options.immediate) {
			var useTitles = this.options.useTitles;
			var callback = this.options.onElementValidate;
			Form.getElements(this.form).each(
				function(input) {
					Event.observe(input, 'blur',
						function(ev){
							Validation.runtime.advice = false;
							Validation.runtime.elm = Event.element(ev);
							Validation.runtime.options = {useTitle : useTitles, onElementValidate : callback};
							setTimeout('Validation.validate()',100);
							for (obj=Event.element(ev).parentNode; obj.tagName!='TD'; obj=obj.parentNode) {;}
							obj = obj.nextSibling;
							if (obj && obj.className=='helpMsg' && obj.innerHTML!='') {
								obj.firstChild.style.display = 'none';
							}
						}
					);
					Event.observe(input, 'click', 
						function(ev){
							for (obj=Event.element(ev).parentNode; obj.tagName!='TD'; obj=obj.parentNode) {;}
							obj = obj.nextSibling;
							if (obj && obj.className=='helpMsg' && obj.innerHTML != '') {
								obj.firstChild.style.display = 'block';
							}
						}
					);
				}
			);
		}
	},
	onSubmit :  function(ev){
		Event.stop(ev);
		this.validate();
	},
	validate : function() {
		Validation.runtime.advice = true;
		var result = false;
		var useTitles = this.options.useTitles;
		var callback = this.options.onElementValidate;
		if(this.options.stopOnFirst) {
			result = Form.getElements(this.form).all(function(elm) { return Validation.validate(elm,{useTitle : useTitles, onElementValidate : callback}); });
		} else {
			result = Form.getElements(this.form).collect(
				function(elm) {
					return Validation.validate(elm,{useTitle : useTitles, onElementValidate : callback}); 
				}
			).all();
		}
		if(!result && this.options.focusOnError) {
			Form.getElements(this.form).findAll(function(elm){return $(elm).hasClassName('validation-failed')}).first().focus()
		}
		this.options.onFormValidate(result, this.form);
		return result;
	},
	reset : function() {
		Form.getElements(this.form).each(Validation.reset);
	}
}

Object.extend(
	Validation, {
		runtime : {
			advice:true,
			checkNow:true,
			elm:{},
			options:{}
		},
		validate : function(elm, options){
			if(Validation.runtime.checkNow){
				if(!elm) {
					elm = Validation.runtime.elm;
				}
				if(!options) {
					optioins = Validation.runtime.options;
				}
				options = Object.extend(
					{
						useTitle : false,
						onElementValidate : function(result, elm) {}
					},
					options || {}
				);
				elm = $(elm);
				var cn = elm.classNames();
				return result = cn.all(
					function(value) {
						var test = Validation.test(value,elm,options.useTitle);
						options.onElementValidate(test, elm);
						return test;
					}
				);
			}
		},
		test : function(name, elm, useTitle) {
			if(elm.type=='submit') {
				return true;
			}
			var v = Validation.get(name);
			var prop = '__advice'+name.camelize();
			try {
				if(Validation.isVisible(elm) && !v.test($F(elm), elm)) {
					if(!elm[prop]) {
						var advice = Validation.getAdvice(name, elm);
						if(advice == null) {
							var errorMsg = useTitle ? ((elm && elm.title) ? elm.title : v.error) : v.error;
							advice = '<br><span class="validation-advice" id="advice-' + name + '-' + Validation.getElmID(elm) +'" style="display:none;">' + errorMsg + '</span>'
							switch (elm.type.toLowerCase()) {
								case 'checkbox':
								case 'radio':
									var p = elm.parentNode;
									if(p) {
										new Insertion.Bottom(p, advice);
									} else {
										new Insertion.After(elm, advice);
									}
									break;
								default:
									new Insertion.After(elm, advice);
							}
						}
					}
					var advice = Validation.getAdvice(name, elm);
					if (Validation.runtime.advice) {
						if (document.all) {
							advice.show();
						} else {
							advice.style.display = 'inline';
							advice.style.display = 'table-cell';

						}
					} else {
						advice.hide();
					}

					elm[prop] = true;
					if (elm.type == 'text'){
						elm.removeClassName('validation-passed');
						elm.addClassName('validation-failed');
					}
					return false;
				} else {
					var advice = Validation.getAdvice(name, elm);
					if(advice != null) advice.hide();
					elm[prop] = '';
					if (elm.type == 'text'){
						elm.removeClassName('validation-failed');
						elm.addClassName('validation-passed');
					}
					return true;
				}
			} catch(e) {
				throw(e)
			}
		},
		isVisible : function(elm) {
			while(elm.tagName != 'BODY') {
				if(!$(elm).visible()) return false;
				elm = elm.parentNode;
			}
			return true;
		},
		getAdvice : function(name, elm) {
			return $('advice-' + name + '-' + Validation.getElmID(elm)) || $('advice-' + Validation.getElmID(elm));
		},
		getElmID : function(elm) {
			return elm.id ? elm.id : elm.name;
		},
		reset : function(elm) {
			elm = $(elm);
			var cn = elm.classNames();
			cn.each(function(value) {
				var prop = '__advice'+value.camelize();
				if(elm[prop]) {
					var advice = Validation.getAdvice(value, elm);
					advice.hide();
					elm[prop] = '';
				}
				if (elm.type == 'text'){
					elm.removeClassName('validation-failed');
					elm.removeClassName('validation-passed');
				}
			});
		},
		add : function(className, error, test, options) {
			var nv = {};
			nv[className] = new Validator(className, error, test, options);
			Object.extend(Validation.methods, nv);
		},
		addAllThese : function(validators) {
			var nv = {};
			$A(validators).each(function(value) {
					nv[value[0]] = new Validator(value[0], value[1], value[2], (value.length > 3 ? value[3] : {}));
				});
			Object.extend(Validation.methods, nv);
		},
		get : function(name) {
			return  Validation.methods[name] ? Validation.methods[name] : Validation.methods['_LikeNoIDIEverSaw_'];
		},
		methods : {
			'_LikeNoIDIEverSaw_' : new Validator('_LikeNoIDIEverSaw_','',{})
		}
}
);
Validation.add('IsEmpty', '',
	function(v) {
		return  ((v == null) || (v.length == 0) || v.match(/^\s+$/)); // || /^\s+$/.test(v));
	}
);
Validation.addAllThese([
	['required', __('This is a required field.'), function(v) {
				return !Validation.get('IsEmpty').test(v);
			}],
	['validate-number', __('Please enter a valid number in this field.'), function(v) {
				return Validation.get('IsEmpty').test(v) || (!isNaN(v) && !/^\s+$/.test(v));
			}],
	['validate-digits', __('Please use numbers only in this field. please avoid spaces or other characters such as dots or commas.'), function(v) {
				return Validation.get('IsEmpty').test(v) ||  !/[^\d]/.test(v);
			}],
	['validate-alpha', __('Please use letters only (a-z) in this field.'), function (v) {
				return Validation.get('IsEmpty').test(v) ||  /^[a-zA-Z]+$/.test(v)
			}],
	['validate-alphanum', __('Please use only letters (a-z) or numbers (0-9) only in this field. No spaces or other characters are allowed.'), function(v) {
				return Validation.get('IsEmpty').test(v) ||  !/\W/.test(v)
			}],
	['validate-date', __('Please enter a valid date (yyyy-mm-dd).'), function(v) {
				return Validation.get('IsEmpty').test(v) ||  /^(19|20)[0-9]{2}-([1-9]|0[1-9]|1[012])-([1-9]|0[1-9]|[12][0-9]|3[01])+$/.test(v);
			}],
	['validate-email', __('Please enter a valid email address. For example fred@domain.com .'), function (v) {
				return Validation.get('IsEmpty').test(v) || /\w{1,}[@][\w\-]{1,}([.]([\w\-]{1,})){1,3}$/.test(v)
			}],
	['validate-url', __('Please enter a valid URL.'), function (v) {
				return Validation.get('IsEmpty').test(v) || /^(http|https|ftp):\/\/([A-Z0-9][A-Z0-9_-]*)(:(\d+))?\/?/i.test(v)
			}],
	['validate-date-au', __('Please use this date format: dd/mm/yyyy. For example 17/03/2006 for the 17th of March, 2006.'), function(v) {
				if(Validation.get('IsEmpty').test(v)) return true;
				var regex = /^(\d{2})\/(\d{2})\/(\d{4})$/;
				if(!regex.test(v)) return false;
				var d = new Date(v.replace(regex, '$2/$1/$3'));
				return ( parseInt(RegExp.$2, 10) == (1+d.getMonth()) ) && 
							(parseInt(RegExp.$1, 10) == d.getDate()) && 
							(parseInt(RegExp.$3, 10) == d.getFullYear() );
			}],
	['validate-currency-dollar', __('Please enter a valid $ amount. For example $100.00 .'), function(v) {
				// [$]1[##][,###]+[.##]
				// [$]1###+[.##]
				// [$]0.##
				// [$].##
				return Validation.get('IsEmpty').test(v) ||  /^\$?\-?([1-9]{1}[0-9]{0,2}(\,[0-9]{3})*(\.[0-9]{0,2})?|[1-9]{1}\d*(\.[0-9]{0,2})?|0(\.[0-9]{0,2})?|(\.[0-9]{1,2})?)$/.test(v)
			}],
	['validate-selection', __('Please make a selection'), function(v,elm){
				return elm.options ? elm.selectedIndex > 0 : !Validation.get('IsEmpty').test(v);
			}],
	['validate-passwordag', __('Same password'), function(v,elm){
				if (elm.name.search(/\[0\]/) == -1) {
					return (v==elm.previousSibling.previousSibling.value);
				} else if (elm.name.search(/\[1\]/) == -1 && elm.nextSibling.nextSibling.value) {
					return (v==elm.nextSibling.nextSibling.value);
				} else {
					return true;
				}
			}],
	['validate-one-required', __('Please select one of the above options.'), function (v,elm) {
				var p = elm.parentNode;
				var options = p.getElementsByTagName('INPUT');
				return $A(options).any(function(elm) {
					return $F(elm);
				});
			}]
]);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -