javascript下4个跨浏览器必备的函数

  下面四个函数就是其中的一部分。

  首先我们要添加一段浏览器检测脚本:

  

复制代码 代码如下:

  /************************************

  * 检测浏览器

  ***********************************/

  var user = navigator.userAgent;

  var browser = {};

  browser.opera = user.indexOf("Opera") > -1 && typeof window.opera == "object";

  browser.khtml = (user.indexOf("KHTML") > -1 || user.indexOf("AppleWebKit") > -1 || user.indexOf("Konqueror") > -1) && !browser.opera;browser.ie = user.indexOf("MSIE") > -1 && !browser.opera;

  browser.gecko = user.indexOf("Gecko") > -1 && !browser.khtml;

  if ( browser.ie ) {

  var ie_reg = /MSIE (\d+\.\d+);/;

  ie_reg.test(user);

  var v = parseFloat(RegExp["$1"]);

  browser.ie55 = v <= 5.5;

  browser.ie6 = v <= 6;

  }

  一) 添加事件绑定 bind()

  这个想必大家都已知道。IE 的事件绑定函数是 attachEvent;而 Firefox, Safari 是 addEventListener;Opera 则两种都支持。下面进行封装。

  

复制代码 代码如下:

  /************************************

  * 添加事件绑定

  * @param obj : 要绑定事件的元素

  * @param type : 事件名称。不加 "on". 如 : "click" 而不是 "onclick".

  * @param fn : 事件处理函数

  ************************************/

  function bind( obj, type, fn ) {

  if ( obj.attachEvent ) {

  obj['e'+type+fn] = fn;

  obj[type+fn] = function(){obj['e'+type+fn]( window.event );}

  obj.attachEvent( 'on'+type, obj[type+fn] );

  } else

  obj.addEventListener( type, fn, false );

  }

  例如添加一个页面点击事件:

  bind(document, "click", function() {

  alert("Hello, World!!");

  });

  二) 删除事件绑定 unbind()

  和 bind() 函数参数相同,功能相反。

  

复制代码 代码如下:

  /************************************

  * 删除事件绑定

  * @param obj : 要删除事件的元素

  * @param type : 事件名称。不加 "on". 如 : "click" 而不是 "onclick"

  * @param fn : 事件处理函数

  ************************************/

  function unbind( obj, type, fn ) {

  if ( obj.detachEvent ) {

  obj.detachEvent( 'on'+type, obj[type+fn] );

  obj[type+fn] = null;

  } else

  obj.removeEventListener( type, fn, false );

  }

  三) 获取元素的计算样式

  计算样式也叫最终样式,也就是元素最终呈现出来的样式。IE 用的是元素的 currentStyle 属性,而其他浏览器则是标准的 document.defaultView.getComputedStyle() 方法。

  

复制代码 代码如下:

  /************************************

  * 返回元素的计算样式

  * @param element : 元素

  * @param key : 样式名称(骆驼)

  ************************************/

  function getStyle(element, key) {

  // 参数不正确

  if ( typeof element != "object" || typeof key != "string" || key == "" )

  return false;

  // 不透明度

  if( key == "opacity" ) {

  if(browser.ie) {

  var f = element.filters;

  if(f && f.length > 0 && f.alpha) {

  return (f.alpha.opacity / 100);

  }

  return 1.0;

  }

  return document.defaultView.getComputedStyle(element, null)["opacity"];

  }

  // 浮动

  if ( key == "float" ) {

  key = (browser.ie ? "styleFloat" : "cssFloat");

  }

  if ( typeof element.currentStyle != "undefined" ){

  return element.currentStyle[key];

  } else {

  return document.defaultView.getComputedStyle(element, null)[key];

  }

  }

  IE 和其他浏览器的透明度机制不一样,这里统一用 opacity 表示透明度。还有,由于 float 是 JavaScript 的保留字,所以浏览器对其进行了转义,IE 用的是 styleFloat,其他则为 cssFloat。这里统一为 float。

  例如:获取透明度

  

复制代码 代码如下:

  var a = document.getElementById("test");

  var opacity = getStyle(a, "opacity");

  四) DOM 加载完毕事件绑定 domready()

  domready 和 window.onload 有所不同,window.onload 是页面所有元素全部加载完毕,包括图像,视频等一些东西。而一般情况下我们不需要等那么久,而只需要 DOM 可用即可。

  

复制代码 代码如下:

  /************************************

  * domready

  * @param fn: 要执行的函数

  ************************************/

  function domready(fn) {

  // 参数不正确

  if(typeof fn != "function")

  return false;

  if(typeof document.addEventListener == "function") { // 非 IE 浏览器

  document.addEventListener("DOMContentLoaded", fn, false);

  return;

  }

  var _this = arguments.callee;

  if(_this.ready) // 如果 DOM 已经加载完毕, 则直接执行

  return fn();

  if(!_this.list) // 创建一个待执行函数数组

  _this.list = [];

  _this.list.push(fn);

  if (_this.done) return; // 正在循环检测则返回

  (function() { // 循环检测

  _this.done = true;

  try {

  document.documentElement.doScroll("left");

  } catch(error) {

  setTimeout(arguments.callee, 0);

  return;

  }

  // DOM 加载完毕, 执行所有待执行函数

  _this.ready = true;

  for (var i=0, l=_this.list.length; i<l; i++) {

  _this.list[i]();

  }

  })();

  }

  例如:

  

复制代码 代码如下:

  domready(function(){

  alert("DOM 加载完毕!");

  });