首先:如何处理兼容问题

1.如果两个都是属性,用逻辑||做兼容

2.如果有一个是方法,用三元做兼容

3.如果是多个属性或方法,封装函数做兼容

分享两个小知识点:

1、取消拖拽的默认行为:

document.ondragstart = function(){

  return false

}

2、阻止右键菜单的默认行为:

document.oncontextmenu = function(){

  return false

}

开始兼容问题:

一、运用逻辑运算符||做的相关兼容

1、关于获取滚动高度的不兼容问题

var scrollTop=documentElement.scrollTop

var scrollTop=document.body.scrollTop(chrome写法)

兼容写法:

var scrollTop = document.documentElement.scrollTop||document.body.scrollTop

2、关于获取事件对象的兼容:

function (eve){

  var e = eve || window.event

}

3、获取键盘编码的兼容:

function (eve){

  var e = eve || window.event

  var keyValue = e.keyCode || e.charCode || e.which

}

4、关于事件委托获取事件源的兼容问题:

function (eve){

  var e = eve || window.event

  var target = e.target || e.srcElement

}

二、运用三元表达式做的兼容

1、阻止事件冒泡的兼容

function (eve){

  var e = eve || window.event

  e.stopPropagation ? e.stopPropagation : e.cancleBubble = true;

}

2、阻止超链接的默认行为:

oA.onclick = function (eve){

  var e = eve || window.event

  e.preventDefault ? e.preventDefault() : e.returnValue = false

}

三、运用方法进行兼容的问题:

1、添加事件监听:

function addEventListener(obj,event,fn,boo){

if(obj.addEventListener){

obj.addEventListener(event,fn,boo);

}else{

    obj.attachEvent("on" + event,fn);

  }

}

运用:

addEventListener(oBtn,"click",fn1,false);

addEventListener(oBtn,"click",fn2,false);

addEventListener(oBtn,"click",fn3,false);

2、移除事件监听:

function removeEventListener(obj,evt,fn,boo){

if(obj.removeEventListener){

    obj.removeEventListener(evt,fn,boo);

}else{

    obj.detachEvent("on" + evt,fn);

  }

}

removeEventListener(oBtn,"click",fn2,false);

3、获取鼠标键值的兼容:(event.button)

function getbutton(eve){

  var e = eve || window.event;

  if(eve){//判断是否为标准浏览器

  return e.button

}else if(window.event){//判断是不是IE

switch(e.button){

case 1 :  return 0;

case 4 :  return 1;

case 2 :  return 2;

}}}

二:关于使用getAttribute获取className不兼容的问题

<div id="box1"></div>

var oBox=document.getElementById("box1")

(1)console.log(oBox.getAttribute("className"))//标准浏览器不支持,ie7支持

(2)console.log(oBox.getAttribute("class")//标准浏览器支持,ie7不支持

兼容写法:

function fn(obj){

if(obj.getAttribute("class"))==null{

return obj.getAttribute("className");

}else{

 return obj.getAttribute("class")

}

};

三:关于getElementsByClassName("class属性名称")的不兼容问题;

console.log(obj.getElementsByClassName("class属性名称"))//标准浏览器支持,ie8以下不支持

兼容写法:

function fn(obj.class属性名称){

if(obj.getElementsByClassName){

return   obj.getElementsByClassName(className);

}else{

var list = [];

var arr = obj.getElementsByTagName(*)//上一步是获取页面所有的标签元素

for(var i = 0;i < arr.length;i ++){

if(arr[i].className == className){

list.push(arr[i]);

}

}

return list;}}

遍历所有元素,找出class名为指定名字的元素

四: 关于处理空白文本节点的问题

1.忽略空白文本节点

function fn(nodes){

var arr = [];

for(var i = 0;i < nodes.length;i ++){

if(nodes[i].nodeType === 3 &&

/^\s+$/.test(nodes[i].nodeValue)){

continue;

}else{

arr.push(nodes[i]);

}}    return arr;}

2.删除空白文本节点:

function fn(nodes){//nodes;所有的子节点

for(var i = 0;i < nodes.length;i ++){

if(nodes[i].nodeType === 3 &&

/^\s+$/.test(nodes[i].nodeValue)){

nodes[i].parentNode.removeChild(nodes[i]);}}

return nodes

}

3.移除空白节点

function fn(node){//node:父节点

var childs = node.childnodes;//获取所有子节点

for(var i = 0;i < childs.length;i ++){

if(childs[i].nodeType === 3 &&

/^\s+$/.test(childs[i].nodeValue)){

node.removeChild(childs[i]);}}

return node;

}

五:获取非行内样式的兼容写法

function getStyle(obj,attr){

return obj.currentStyle ? obj.currentStyle[attr] : getComputedStyle(obj,true)[attr];

}

attr:是属性;比如

<style>#box{width:100px;}</style>

<div id = box></div>

<script>

var oBox = document.getElementById("box");

function getStyle(obj,attr){

return obj.currentStyle ?       obj.currentStyle[attr] :      getComputedStyle(obj,true[attr];

};

var s = getStyle(oBox,"width");

alert(s);

</script>

如何处理使用js兼容所有浏览器的问题的更多相关文章

  1. JS兼容各个浏览器的本地图片上传即时预览效果

    JS兼容各个浏览器的本地图片上传即时预览效果 很早以前 在工作曾经碰到这么一个需求,当时也是纠结了很久,也是google了很久,没有碰到合适的demo,今天特意研究了下这方面的的问题,所以也就做了个简 ...

  2. js兼容各个浏览器的复制功能

    看似简单的复制功能,用js做起来竟然遇到各种情况.刚开始在网上搜索到复制功能的几种实现方法,但是都不兼容.最后还是用的插件代码如下 html模板 <tr> <td>1</ ...

  3. JS兼容IE浏览器的方法

    背景 系统需要兼容蛋疼的IE6... 解决方案 *{ 兼容IE6-8 }* <!--[if lt IE 9]> <script src="@{'/public/mng/ja ...

  4. js兼容多浏览器的关闭当前页面

    关闭当前页面,相信不少人在开发中都遇到过这个需求,但面对这么多的浏览器,要做到js的兼容还需要做特殊的处理.关于这方面网上有很多的资料,但大多都是复制粘贴的,没有达到兼容的效果,或者是效果不好. 下面 ...

  5. 调用iframe 中的js[兼容各种浏览器]

    *chrome浏览器需要在服务器环境中测试 <!DOCTYPE html> <html> <head> <meta http-equiv="cont ...

  6. JS兼容各个浏览器的本地图片上传即时预览效果\、

    在firefox\chrome\ie10等浏览器中可以使用HTML5中的内容实现图片即时预览效果,在IE10以下浏览器中使用滤镜来解决图片显示问题. HTML5中的FileReader对象主要是把文件 ...

  7. ZeroClipboard.js兼容各种浏览器复制到剪切板上

    http://www.cnblogs.com/huijieoo/articles/5569990.html <script type="text/javascript" sr ...

  8. JS兼容所有浏览器的一段加入收藏代码,设置为首页

    <script language="javascript" type="text/javascript"> function addfavorite ...

  9. JS获取回车事件(兼容各浏览器)

    一.用到onkeydown获取事件动作, 二.用到键盘对应代码keyCode, 三. var event=arguments.callee.caller.arguments[0]||window.ev ...

随机推荐

  1. 消息中间件ActiveMQ及Spring整合JMS的介绍

    一 .消息中间件的基本介绍 1.1 消息中间件 1.1.1 什么是消息中间件 消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成.通过提供消息传递和消息排 ...

  2. 几种文件查找命令,whereis ,find ,locate.

    whereis对于文件的查找,是将系统内的所有文件放在一个数据库文件里.whereis 和 locate 都是以该数据库为准的(由于每个数据库会有一个更新时间,一般在更新时间之后才可以找到).而fin ...

  3. mysql数据库第三弹

    mysql数据库知识拓展 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. SELECT ...

  4. linux操作系统基础篇(四)

    一.系统监控 1.TOP 命令 1) top命令的功能:top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器. 2) 使用top命令列 ...

  5. Storm入门之第一章

    Storm入门之第一章 1.名词 spout龙卷,读取原始数据为bolt提供数据 bolt雷电,从spout或者其他的bolt接收数据,并处理数据,处理结果可作为其他bolt的数据源或最终结果 nim ...

  6. Upgrading an ASP.NET MVC 2 Project to ASP.NET MVC 3 Tools Update

    ASP.NET MVC 3 can be installed side by side with ASP.NET MVC 2 on the same computer, which gives you ...

  7. 使用Jedis操作redis 缓存

    案例:http://blog.csdn.net/linlzk/article/details/41801391 Redis是一个开源的Key-Value数据缓存,和Memcached类似. Redis ...

  8. Python 日志处理(二) 使用正则表达式处理Nginx 日志

    使用正则表达式来处理Nginx 日志 一. 先对单行的日志进行分组正则匹配,返回匹配后的结果(字典格式): from datetime import datetime import re #单行日志 ...

  9. Python 学习之路2

    这是我在大学上机实验的作业 实验一 将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5. 首先,先谈下我的设计思路: 设计思路: 1.    先需判断输入的number是不是一个数字( ...

  10. 2017计算机学科夏令营上机考试-A判决素数个数

    A:判决素数个数 总时间限制:  1000ms 内存限制:  65536kB 描述 输入两个整数X和Y,输出两者之间的素数个数(包括X和Y). 输入 两个整数X和Y(1 <= X,Y <= ...