common.js

function openwinx(url,name,w,h)
{
    window.open(url,name,"top=100,left=400,width=" + w + ",height=" + h + ",toolbar=no,menubar=no,scrollbars=yes,resizable=no,location=no,status=no");
}

function Dialog(url,name,w,h)
{
	return showModalDialog(url, name, 'dialogWidth:'+w+'px; dialogHeight:'+h+'px; help: no; scroll: yes; status: no');
}

//表单常用docform=document.forms[i]
function loadURLAction (url,docform,submittype){
	docform.action = url;
    docform.method = submittype;   //设置提交方式 
    docform.submit();
}

function doSubmit (docform,url){
    docform.action = url;
    docform.submit();
}

function doReset (docform){
    docform.reset();
}

function doRefresh (){
	self.location.reload();
}
 

表中不填还原默认值,提交调用验证(适合新增页面 ,不适合修改)

//如果input为空,还原input 默认值
function resetFields(whichform) {
	for (var i=0; i<whichform.length; i++) {
        var element = whichform.elements[i];
        if (element.type == "submit") continue;
        if (element.type == "radio") continue;
        if (element.type == "checkbox") continue;
 if (!element.defaultValue) continue;
       
        element.onfocus = function() {
            if (this.value == this.defaultValue) {
                this.value = "";   
            }
        }    
        element.onblur = function() {
            if (this.value == "") {
                this.value = this.defaultValue;   
            }   
        }
    }   
}

function prepareForms() {
    for (var i=0; i<document.forms.length; i++) {
        var thisform = document.forms[i];
        resetFields(thisform);
      /*  thisform.onsubmit = function() {
            return validataForm(this);
        }*/
    }
}

addLoadEvent(prepareForms);
 

class attribute

/**
 * 为对象添加 className
 * @param {Object} 需要添加className的节点
 * @param {String}  要添加的 className
 */
function addClass(element,value) {
    if (!element.className) {
        element.className = value;
    }else {
        newClassName = element.className;
        newClassName+= " ";
        newClassName+= value;
        element.className = newClassName;
    }   
}

/**
 * 为对象删除 className
 * @param {Object} 需要删除className的节点
 * @param {String}  要删除的 className
 */
function removeClass(el, cls) {
	var el = $(el);
	if(!el) return;
	el.className = el.className.replace(new RegExp("(^|\\s+)" + cls + "(\\s+|$)"), ' ');
}

/**
 * 判断对象是否存在该 className
 * @param {Object} 需要判断className的节点
 * @param {String}  要判断的 className
 */
function hasClass(node, className) {
	var elementClassName = node.className;
	return (elementClassName.length > 0 && (elementClassName == className || new RegExp("(^|\\s)" + className + "(\\s|$)").test(elementClassName)));
}	

/* grab Elements from the DOM by className */
function getElementsByClass(searchClass,node,tag) {
	var classElements = new Array();
	if ( node == null )
		node = document;
	if ( tag == null )
		tag = '*';
	var els = node.getElementsByTagName(tag);
	var elsLen = els.length;
	var pattern = new RegExp("(^|\\s)"+searchClass+"(\\s|$)");
	for (i = 0, j = 0; i < elsLen; i++) {
		if ( pattern.test(els[i].className) ) {
			classElements[j] = els[i];
			j++;
		}
	}
	return classElements;
}

浏览器检测

var BROWSER = {};
var USERAGENT = navigator.userAgent.toLowerCase();
browserVersion({'ie':'msie','firefox':'','chrome':'','opera':'','safari':'','maxthon':'','mozilla':'','webkit':''});
if(BROWSER.safari) {
	BROWSER.firefox = true;
}
BROWSER.opera = BROWSER.opera ? opera.version() : 0;
function browserVersion(types) {
	var other = 1;
	for(i in types) {
		var v = types[i] ? types[i] : i;
		if(USERAGENT.indexOf(v) != -1) {
			var re = new RegExp(v + '(\\/|\\s)([\\d\\.]+)', 'ig');
			var matches = re.exec(USERAGENT);
			var ver = matches != null ? matches[2] : 0;
			other = ver !== 0 ? 0 : other;
		}else {
			var ver = 0;
		}
		eval('BROWSER.' + i + '= ver');
	}
	BROWSER.other = other;
}
if(BROWSER.ie){alert('232');}else{alert('ff');}

sdfsd

/* quick getElement reference */
function $() {
	var elements = new Array();
	for (var i = 0; i < arguments.length; i++) {
		var element = arguments[i];
		if (typeof element == 'string')
			element = document.getElementById(element);
		if (arguments.length == 1)
			return element;
		elements.push(element);
	}
	return elements;
}

function getParameter(name){
    var search = document.location.search;
    var pattern = new RegExp("[?&]"+name+"\=([^&]+)", "g");
    var matcher = pattern.exec(search);
    var items = null;
    if(null != matcher){
        items = decodeURIComponent(matcher[1]);
        //items = unescape(matcher[1]);
    }
    return items;
}

function isUndefined(variable) {
    return typeof variable == 'undefined' ? true : false;
}

function dwrite(ht_str) {
	document.write(ht_str);
}

function addEvent(elm, evType, fn, useCapture) {
	if (elm.addEventListener) {   // Mozilla系列
		elm.addEventListener(evType, fn, useCapture);
		return true;
	}
	else if (elm.attachEvent) {   //IE系列
		var r = elm.attachEvent('on' + evType, fn);
		return r;
	}
	else {
		elm['on' + evType] = fn;
	}
}

var EventCache = function(){
	var listEvents = [];
	return {
		listEvents : listEvents,
		add : function(node, sEventName, fHandler){
			listEvents.push(arguments);
		},
		flush : function(){
			var i, item;
			for(i = listEvents.length - 1; i >= 0; i = i - 1){
				item = listEvents[i];
				if(item[0].removeEventListener){
					item[0].removeEventListener(item[1], item[2], item[3]);
				};
				if(item[1].substring(0, 2) != "on"){
					item[1] = "on" + item[1];
				};
				if(item[0].detachEvent){
					item[0].detachEvent(item[1], item[2]);
				};
				item[0][item[1]] = null;
			};
		}
	};
}();
addEvent(window,'unload',EventCache.flush);

function addLoadEvent(func) {
    var oldonload = window.onload;
    if (typeof window.onload != 'function') {
        window.onload = func;   
    }else {
        window.onload = function() {
            oldonload();
            func();
        }
    }
}

/**
* 获取Event对象
* @method getEvent
* @return {Event} event对象	
* getEvent();
*/
function getEvent() { //ie && ff
	if(document.all) return window.event;
	func = getEvent.caller;
	while(func != null) {
		var arg0 = func.arguments[0];
		if (arg0) {
			if((arg0.constructor  == Event || arg0.constructor == MouseEvent) || (typeof(arg0) == "object" && arg0.preventDefault && arg0.stopPropagation)) {
				return arg0;
			}
		}
		func=func.caller;
	}
	return null;
}

/*阻止浏览器默认操作*/
function stopDefault() {
	var ev = getEvent();
	if(ev.stopPropagation){ //firefox
		ev.preventDefault();
	}else{ //ie 
		ev.returnValue = false;
	}
}

/*功能:停止事件冒泡*/
function stopBubble() {
	var ev = getEvent();
	if(ev.stopPropagation){ //firefox
		ev.stopPropagation();  
	}else{ //ie 
		ev.cancelBubble = true;
	}
}

/**
 * 禁止Event事件冒泡,阻止默认行为
 * @method stopEvent
 * stopEvent();
*/
function stopEvent() {
	stopDefault();
	stopBubble();
}

function toggle(obj) {
    var el = document.getElementById(obj);
    if ( el.style.display != 'none' ) {
        el.style.display = 'none';
    }else {
        el.style.display = 'block';
    }
}

/* insert an element after a particular node */
function insertAfter(parent, node, referenceNode) {
	parent.insertBefore(node, referenceNode.nextSibling);
}

isUndefined

function ajaxmenu(ctrlObj, timeout, cache, duration, pos, recall) {
    if(isUndefined(pos)) pos = '43';
}

addEvent : 注释:elm元素evType时调用fn函数,useCapture参数:true时为事件捕获(Event capturing) false时为事件冒泡(Event bubblin),默认为false;

  <html xmlns="http://www.w3.org/1999/xhtml">
  <head>
      <title>调用演示</title>
     <script type="text/javascript" language="javascript">
     function addEvent(elm, evType, fn, useCapture) {...}
     function show() {
             alert("Message!"); 
     }
     addEvent(window,"load",show)
     </script>
   </head>
   <body>
      调用演示  
   </body>
  </html>

       注释:我们有getElementById() , getElementsByName() , getElementsByTagName() , 现在终于有了getElementsByClass(),它的作用是找到node中具有相同Class的tag元素;

<html>
<head>
   <title>getElementsByClass()调用演示</title> 
   <script type="text/javascript">
        function getElementsByClass(searchClass,node,tag) {...}
   </script>
</head>
 <body> 
    <input class="aa" value="0"  />
    <div id="wrapper">
        <input class="aa" value="1"  />
        <input class="aa" value="2"  />
        <input class="aa" value="3"  />
        <input class="aa" value="4"  />
        <input class="bbb" value="5"  />
     </div>
    <input  type="button" value="调用函数"  onclick="alert(getElementsByClass('aa',wrapper,'input').length)"/>
</body></html>

 toggler

<html><head> <title>toggle调用演示</title> 
 <script type="text/javascript">
      function toggle(obj) {...}
 </script>
 </head><body> 
    <div id="wrapper">
          xx,到此一游
   </div>
     <input  type="button" value="show"  onclick="toggle('wrapper')"/>
</body></html>

  注释:很奇怪,DOM中给出了insertBefore()方法,却没有insertAfter()方法,不过现在有了这个函数.在目标元素后面插入新的元素

<html>
<head>
<title>insertAfter()调用演示</title> 
 <script type="text/javascript">
      function insertAfter(newElement, targetElement){...}
      window.onload=function(){   
             var new =document.createElement("span");   
             var b =document.createTextNode("new text!");   
             new.appendChild(b);   
             var target = document.getElementById("b");   
             insertAfter(new,target);     
}
 </script>
 </head>
 <body>
     <div id="b">bbb</div>  
</body>
</html>

阻止浏览器默认操作

<script type="text/javascript">  
	function stopDefault( e ) {     
		//适用于火狐等实现了W3C规范的浏览器     
 		if ( e && e.preventDefault )         
 			e.preventDefault();     
 		//适用于IE    
 		else        
 			window.event.returnValue = false;     
 		return false; 
 	}
</script>  
<a href="http://www.google.com" id="testLink">Google</a>  
<script type="text/javascript"> 
 	var test = document.getElementById('testLink'); 
 	test.onclick = function(e) {     
 		alert('我的链接地址是:' + this.href + ', 但是我不会跳转。');     
 		stopDefault(e); 
 	} 
</script>  
 

 

你可能感兴趣的:(JavaScript,Opera,IE,firefox,Safari)