使用js是一件令人很抓狂的事情,很多的浏览器兼容,一大推的代码,谁的脑袋能记住那么多的东西,只有平时多积累,所谓熟能生巧嘛。。这里列出一些常用的兼容代码,一点点积累哈~~~
   
一、以跨浏览器的方式处理事件。这个叫EventUtil对象定义了一些方法,用来处理各浏览器之间的差异。
    
     var EventUtil={
        
         addHandler:function(element,type,handler){//绑定事件
             if(element.addEventListener){
                 element.addEventListener(type,handler,false);
             }else if(element.attachEvent){
                 element.attachEvent("on"+type,handler);
             }else{
                 element["on"+type]=null;
             }
         },
    
         removeHandler:function(element,type,handler){//取消事件
             if(element.removeEventListener){
                 element.removeEventListener(type,handler,false);
             }else if(element.detachEvent){
                 element.detachEvent("on"+type,handler);
             }else{
                 element["on"+type]=null;
             }
         },
        
         getEvent:function(event){//获取event对象
             return event:event?window.event;
         },
 
         getTarget:function(event){//获取事件目标
             return event.target||event.srcElement;
         },
 
         preventDefault:function(event){//阻止默认事件
             if(event.preventDefault){
                  event.preventDefault();
             }else{
                  event.returnValue=flase;
             }
         },
 
         stopPropagation:function(event){//阻止冒泡事件
             if(event.stopPropagation){
                  event.stopPropagation();
             }else{
                  event.cancelBubble=true;
             }
         },
 
         getRelatedTarget:function(event){//mouseover,mouseout通过event提供相关元素信息
             if(event.relatedTarget){
                 return event.relatedTarget;
             }else if(event.toElement){
                 return event.toElement;
             }else if(event.fromElement){
                 return event.fromElement;
             }else{
                 return null;
             }
         },
 
         getButton:function(event){//获取鼠标按下键位
             if(document.implementation.hasFeature("MouseEvents","2.0")){
                 return event.button;
             }else{
                 switch(event.button){
                     case 0:
                     case 1:
                     case 3:
                     case 5:
                     case 7:
                           return 0;
                     case 2:
                     case 6:
                           return 2;
                     case 4:
                           return 1;
                 }
             }
         },
 
         getCharCode:function(event){//键盘按下键的ascii值码
             if(typeof event.charCode=="number"){
                  return event.charCode;
             }else{
                  return event.keyCode;
             }
         },
 
         //clipboardData 剪贴板对象,firefox不支持该对象
         getClipboardData:function(event){//获取剪贴板数据
              var clipboardData=(event.clipboardData||window.clipboardData);
              return clipboardData.getData("text");
         },
        
         setClipboardData:function(event,value){
              if(event.clipboardData){
                  return event.clipboardData.setData("text/plain",value);
              }else if(window.clipboardData){
                  return window.clipboardData.setData("text",value);
              }
         },
     }
 
 
二、对表单的操作兼容的一些函数:
1、取得用户在文本框取得的文本:
      function getSelectedText(textbox){
           if(document.selection){//ie
                return document.selection.creatRange().text;
           }else{
                return textbox.value.substring(textbox.selectionStart,textbox.selectionEnd);
           }
      }
 
2、选择部分文本:
      function selectText(textbox,startIndex,stopIndex){
           if(textbox.setSelectionRange){
                 textbox.setSelectionRange(startIndex,stopIndex);
           }else if(textbox.createTextRange){//ie
                 var range=textbox.createTextRange();
                 range.collapse(true);
                 range.moveStart('character',startIndex);
                 range.moveEnd('character',stopIndex-startIndex);
                 range.select();
           }
           textbox.focus();
      }
 
三、一些常用的js自定义函数。
1、下面这个函数可以辅助向现有的URL的末尾添加查询字符串参数,查询字符串中的每个名称和值都应该用encodeURIComponent()进行编码,不然容易发生请求错误:
      function addURLParam(url,name,value){
           url+=(url.indexof('?')==-1?"?":"&");
           url+=encodeURIComponent(name)+"="+encodeURIComponent(value);
           return url;
      }
 
2、设置和获取cookie:
      var CookieUtil={
          get:function(name){
              var cookieName=encodeURIComponent(name)+"=",
                  cookieStart=document.cookie.indexof(cookieNmae);
                  cookieValue=null;
              if(cookieStart>-1){
                  var cookieEnd=document.cookie.indexof(";",cookieStart);
                  if(cookieEnd==-1){
                      cookieEnd=document.cookie.length;
                  }
                 cookieValue=decodeURIComponent(document.cookie.substring(cookieStart+cookieName.length,cookieEnd));
              }
              return cookieValue;
          },
         
          set:function(name,value,expires,path,domain,secure){
              var cookieText=encodeURIComponent(name)+"="+encodeURIComponent(value);
              if(expires instanceof Date){
                   cookieText+=";expires="+expires.toGMTString();
              }
              if(path){
                   cookieText+=";path="+path;
              }
              if(domain){
                   cookieText+=";domain="+domain;
              }
              if(secure){
                   cookieText+=";secure="+secure;
              }
              return cookieText;
          }
          unset:function(name,path,domain,secure){
              this.set(name,"",new Date(0),path,domain,secure);
          }
      }
 

js 浏览器兼容的一些方法的更多相关文章

  1. JS浏览器兼容问题

    一.JS与DOM的兼容性: (一) DOM节点的访问: 1.以前对DOM节点访问一般用“document.All.元素ID属性值”或者“document.元素ID属性值”这种简化的方法,在FireFo ...

  2. js 浏览器兼容css中webkit、Moz、O、ms...写法封装(es6语法)

    /** *浏览器兼容写法封装 */ let elementStyle = document.createElement('div').style let vendor = (() => { le ...

  3. js浏览器兼容

    //window.event   IE:有window.event对象   FF:没有window.event对象.可以通过给函数的参数传递event对象.如onmousemove=doMouseMo ...

  4. js 浏览器兼容问题及解决办法

    JS中出现的兼容性问题的总结 1.关于获取行外样式 currentStyle 和 getComputedStyle 出现的兼容性问题  我们都知道js通过style不可以获取行外样式,当我们需要获取行 ...

  5. IE9 以下版本浏览器兼容HTML5的方法,使用百度静态资源的html5shiv包

    <!--[if lt IE9]> <script src="http://apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.j ...

  6. scss、less 对浏览器兼容的处理方法, css 的单行溢出、多行溢出

    1. scss @mixin rounded($param1,$param2) {    #{$param1}:$param2;    -webkit-#{$param1}: $param2;     ...

  7. 浅谈CSS hack(浏览器兼容)

    今天简单写一点关于浏览器兼容的处理方法,虽然百度上已经有很多,但是我还是要写! 先看一个图 这个图描述了2016年1月至8月网民们所使用的浏览器市场份额(来源:http://tongji.baidu. ...

  8. 关于浏览器兼容问题及hack写法

    浏览器的兼容问题 1.浏览器内核: Mozilla Firefox ( Gecko ) Internet Explorer ( Trident ) Opera ( Presto ) Safari ( ...

  9. JS中常遇到的浏览器兼容问题和解决方法

    今天整理了一下浏览器对JS的兼容问题,希望能给你们带来帮助,我没想到的地方请留言给我,我再加上: 常遇到的关于浏览器的宽高问题: //以下均可console.log()实验 var winW=docu ...

随机推荐

  1. CDS

    very nice artical talk about mergechangelog and cleardataset Delta and Data http://www.cnblogs.com/y ...

  2. bak骗子公司

    李波 身份证:310101197510313215 手机:13916407777 18621624812 13916821206住址:上海QQ:87766938 沪EE5781 奥迪Q7李寻欢77 s ...

  3. C#中Invoke的用法(转)

    在多线程编程中,我们经常要在工作线程中去更新界面显示,而在多线程中直接调用界面控件的方法是错误的做法,Invoke 和 BeginInvoke 就是为了解决这个问题而出现的,使你在多线程中安全的更新界 ...

  4. Hadoop中如何查看文件的block size

    因为对控制文件的分片数目,进而控制文件的map个数非常感兴趣,因此有查找如下资料的需求.下面来看看我总结的吧:) 当向HDFS上写文件时,可以通过设置dfs.blocksize配置项来设置文件的blo ...

  5. HDU5950(矩阵快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5950 题意:f(n) = f(n-1) + 2*f(n-2) + n^4,f(1) = a , f(2 ...

  6. RabbitMQ - TcpConnection析构引发的一次handshake_timeout

    使用RabbitMQ时,连接rabbit-server一直连接失败,代码没有任何错误提示.但是通过rabbitmqctl始终查询不到连接以及创建的queue等信息. 官方的文件demo里面也没有Tcp ...

  7. 黑苹果-IOS学习的开始

    深知安装黑苹果的不易,在这里写一下关于我的Thinkpad E430c安装黑苹果教程(Mac版本:Yosemite 10.10.4),希望能够帮助有需要的朋友. 首先贴上我的电脑配置报表: ----- ...

  8. CPU指令集

    cpu作为一台电脑中的核心,它的作用是无法替代的.而cpu本身只是在块硅晶片上所集成的超大规模的集成电路,集成的晶体管数量可达到上亿个,是由非常先进复杂的制造工艺制造出来的,拥有相当高的科技含量. C ...

  9. Linux下mysql忘记root密码

    一台机器上的MYSQL服务器很久没用了,忘了root密码无法连接.一时情急,网上搜寻办法,解决,记录在此备用. 修改MySQL的登录设置:  //不同的版本的Linux配置文件的位置也不一样,以Lin ...

  10. SDK截图(四):压缩位图实例

    这个问题研究了两天.<windows程序设计>中没有给出实例,MSDN也没有给出具体的例子.在知道,CSDN提问后,也没有得到答案.所以决定重新对DIB做一次彻底的研究,这大概会花去我一个 ...