$('input,textarea').focus(
	function(){
//		popHint(this);
		if ($(this).attr('msg') != undefined){
			popHint(this);
		}
	}								
);

$('form').submit(
	function(){
		if (chkForm(this)){
			// 防止按钮二次点击
			$('input:submit').attr('disabled', 'true');
			$('input:text').attr('readonly', 'true');
			$('textarea').attr('readonly', 'true');
		}
		else {
			return false;	
		}
	}
);

function chkForm(frm){
	var obj = $(frm);
	var flag = true;
	$('input,textarea', obj).each(
		function(){
			// 必填
			if ($(this).attr('require') == 'true' && $(this).val() == ''){
				popHint($get(this), $(this).attr('msg'), 'blur');
				$(this).focus();
				flag = false;
			}
		}									
	);
	return flag;
}


///////////////////////////////////////////////////////////////////
///
///  表单提示
///
///////////////////////////////////////////////////////////////////
<!--

// 这里都是公用函数，挺多的...
var

// 获取元素
// 定义成$get方法，以免与其它JS框架冲突
$get = function(element) {
	return (typeof(element) == 'object' ? element : document.getElementById(element));
},

// 生成元素到refNode
appendElement = function(tagName, Attribute, strHtml, refNode) {
	var cEle = document.createElement(tagName);
	// 属性值
	for (var i in Attribute){
		cEle.setAttribute(i, Attribute[i]);
	}
	cEle.innerHTML = strHtml;
	
	refNode.appendChild(cEle);
	return cEle;
},

// 获取元素坐标
getCoords = function(node){
	var x = node.offsetLeft;
	var y = node.offsetTop;
	var parent = node.offsetParent;
	while (parent != null){
		x += parent.offsetLeft;
		y += parent.offsetTop;
		parent = parent.offsetParent;
	}
	return {x: x - 5, y: y - 3};
},

// 事件操作(可保留原有事件)
eventListeners = [],
findEventListener = function(node, event, handler){
	var i;
	for (i in eventListeners){
		if (eventListeners[i].node == node && eventListeners[i].event == event && eventListeners[i].handler == handler){
			return i;
		}
	}
	return null;
},
myAddEventListener = function(node, event, handler){
	if (findEventListener(node, event, handler) != null){
		return;
	}
	if (!node.addEventListener){
		node.attachEvent('on' + event, handler);
	}else{
		node.addEventListener(event, handler, false);
	}
	eventListeners.push({node: node, event: event, handler: handler});
},
removeEventListenerIndex = function(index){
	var eventListener = eventListeners[index];
	delete eventListeners[index];
	if (!eventListener.node.removeEventListener){
		eventListener.node.detachEvent('on' + eventListener.event,
		eventListener.handler);
	}else{
		eventListener.node.removeEventListener(eventListener.event,
		eventListener.handler, false);
	}
},
myRemoveEventListener = function(node, event, handler){
	var index = findEventListener(node, event, handler);
	if (index == null) return;
	removeEventListenerIndex(index);
},
cleanupEventListeners = function(){
	var i;
	for (i = eventListeners.length; i > 0; i--){
		if (eventListeners[i] != undefined){
			removeEventListenerIndex(i);
		}
	}
};


/*********************************************
	- POPHint 弹出提示框
**********************************************/
function popHint(obj, msg, initValues) {
	var
	_obj = $get(obj),
	_objHint = $get("popHint"),
	_msg = msg == '' ? msg : $get(obj).require ? $get(obj).msg + '<span style="font-weight:bold; color:#ff0000">(必填!)</span>' : $get(obj).msg ,
	_init = initValues;
	
	// 初始化失败...
	if(_obj==undefined || _msg==undefined || _msg=="") return;
	
	// 设置初始值
	_init = _init==undefined ? {_type : "wrong", _event : "click"} : _init;
	// obj如果不可见。设置弹出对象为obj父元素
	if(_obj.style.display=='none' || _obj.style.visibility=='hidden' || _obj.getAttribute('type')=='hidden') _obj = _obj.parentNode;
	
	var
	_type = null,
	_event = null,
	_place = getCoords(_obj),
	_marTop = null,
	_objText = $get("popHintText"),
	
	// 初始化
	init = function() {
		_hint = _obj.getAttribute("hint");
		if(_hint=="false") return;
		
		// 有的时候initValues不为空.但是只设置一个值...避免发所错误.再次设置初始值...
		_type = _init._type==undefined ? "wrong" : _init._type;
		_type = _type.toLowerCase();
		_event = _init._event==undefined ? "click" : _init._event;
		_event = _event.toLowerCase();
		
		var _Html = "<div id=\"popHeader\">" +
					"    <div class=\"popLeft\"></div>" +
					"    <div id=\"popHintText\"></div>" +
					"    <div class=\"popRight\"></div>" +
					"</div>"+
					"<div class=\"popAngle\"><span></span></div>"
		
		if(_objHint==null) {
			_objHint = appendElement("div", {"id" : "popHint"}, _Html, document.body);
			_objHint.style.display = "none";
			_objText = $get("popHintText");
		}
		
		show();
	},
	// 显示
	show = function() {
		_objHint.style.display = "";
		_marTop = _objHint.offsetHeight;
		
		_msg = "<span class=\"popIcon "+ _type +"\"></span>"+ _msg;
		_objText.innerHTML = _msg;
		
		_objHint.style.left = _place.x +"px";
		_objHint.style.top = (_place.y-_marTop+8) +"px";
		
		// 关闭触发事件
		switch(_event) {
			case "blur" :
				myAddEventListener(_obj, 'blur', hide);
				break;
			//default :
			case "click" :
				myAddEventListener(document, 'mousedown', hide);
				break;
			//这里可以自己扩展很多事件...
		}
	},
	// 关闭
	hide = function() {
		_objHint.style.display = "none";
		_objText.innerHTML = "";
		// 移除关闭触发事件
		myRemoveEventListener(_obj, 'blur', hide);
		myRemoveEventListener(document, 'mousedown', hide);
	};
	
	init();
}