微软交流社区

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 159|回复: 10

JavaScript兼容性汇总

[复制链接]

2

主题

6

帖子

10

积分

新手上路

Rank: 1

积分
10
发表于 2023-3-31 14:48:31 | 显示全部楼层 |阅读模式
​   一般兼容性问都体现到DOM和事件上
​   只聊ie6+版本浏览器,希望小伙伴们别纠结更低版本浏览器哈^_^
DOM

获取元素


  • document.getElementsByclassName     不兼容ie6 7 8
  • 解决方法:
function getByClass(oParent,sClass) {
  var aResult=[];

  var aEle=oParent.getElementsByTagName("*");

  var re=new RegExp("\\b"+sClass+"\\b","i");

  for (var i=0;i<aEle.length;i++)
  {
     if(re.test(aEle.className))
     {
       aResult.push(aEle);  
     }   
  }
  return aResult;
}

  • document.querySelector      不兼容ie6 7
    这个选择器获取方法还是很推荐使用的
    解决方法:可以使用 getElementById

  • document.querySelectorAll 不兼容ie6 7
    这个选择器获取方法还是很推荐使用的,和上面不同的事,它是获取一组元素
    解决方法:可以使用 getElementsByTagName 或者 上面封装的getByClass
属性


  • 自定义属性操作方法
getAttribute(name)                不兼容ie6 7

setAttribute(name,value)     不兼容ie6 7

removeAttribute(name)           不兼容ie6 7、
   解决方法:
// 个人建议加加载完html,使用js给标签赋值
obj.index = 1                                                // 设置
console.log(obj.index)        // 获取
obj.index = ''                                        // 清空

  • 自定义属性data-*        不兼容ie6 7 8 9 10
  console.log(obj.dataset.name)               获取

   obj.dataset.name =  value                     设置      

   解决方法:
function getDataset(ele){
    if(ele.dataset){
        return ele.dataset;
    }else{
        var attrs = ele.attributes,
            dataset = {},
            name,
            matchStr;

        for(var i = 0;i<attrs.length;i++){
            matchStr = attrs.name.match(/^data-(.+)/);
            if(matchStr){
                name = matchStr[1].replace(/-([\da-z])/gi,function(all,letter){
                    return letter.toUpperCase();
                });
                dataset[name] = attrs.value;
            }
        }
        return dataset;
    }
}

  • 操作class方法
   classList.add('name')                   不兼容ie6 7 8 9

   classList.remove('name')              不兼容ie6 7 8 9

   解决方法:
function addClass(obj, class){
  if(!this.contains(class)){
    obj.className +=' ' + class;
  }
}
function removeClass(obj,class){
  if(obj.className.indexOf(class) !== -1){
    var reg= new RegExp(class);   
    obj.className =  obj.className.replace(reg,'');
  }
}节点


  • 节点类一起总结: 前面的不兼容ie6
// 获取子节点
var children = obj.children || obj.childNodes
// 获取第一个子节点
var first = obj.firstElementChild || obj.firstChild
// 获取最后一个子节点
var last = obj.lastElementChild || obj.lastChild
// 获取上一个兄弟节点
var prev = obj.previousElementSibling || obj.nextElementSibling
// 获取下一个兄弟节点
var next = obj.nextElementSibling || obj.nextElementSibling
滚动距离

// 有文档头
// - docuemnt.documentElement.scrollTop / scrollLeft
// 没有文档头
// - document.body.scrollTop / scrollLeft

// 兼容
var top = docuemnt.documentElement.scrollTop || document.body.scrollTop
var left = docuemnt.documentElement.scrollLeft || document.body.scrollLeft

  • 浏览器可视区大小
// 包含工具条与滚动条
// - document.documentElement.clientWidth / clientHeight
// 不包含工具条与滚动条
// - window.innerWidth / innerHeight
// - 使用 outerWidth 和 outerHeight 属性获取加上工具条与滚动条窗口的宽度与高度
事件


  • 事件对象
// 事件对象
// ev 不兼容ie 6 7 8
// window.event 兼容所有浏览器
document.onclick = function (ev) {
    ev = ev || window.event
}

  • 获取页面中鼠标位置
ev.pageX/ev.pageY  不兼容ie6 7 8
  解决方案:
var x = ev.clientX + document.documentElement.scrollLeft
var y = ev.clientY + document.documentElement.scrollTop

  • 获取键盘码
ev.keyCode  不兼容火狐
ev.which 不兼容 ie6 7 8
   解决方案:
var code = keyCode || which

  • 获取事件源
ev.target 不兼容 ie6 7 8

ev.srcElement 兼容所有浏览器

   解决方案:
var src = target || srcElement

  • 阻止默认行为
ev.preventDefault()       不兼容ie6 7 8
ev.returnValue = false   兼容所有浏览器
解决方案:
function stopDefault(ev) {
    if (ev && ev.preventDefault) {
        ev.preventDefault()
    } else {
        event.returnValue = false
    }
    return false;
}

  • 阻止事件冒泡
e.stopPropagation()       不兼容ie6 7 8
ev.cancelBubble = true   兼容所有浏览器
解决方案:
function stopPropagat(ev){
    if (ev&& evstopPropagation) {
        evstopPropagation()
    } else {
        event.cancelBubble = true
    }
}

  • 事件绑定
obj.addEventListener      不兼容9+
obj.attachEvent   兼容ie6 7 8
   解决方案:
function on(obj, type, fn){
    if(obj.addEventListener){   
        obj.addEventListener(type, fn, false)
    }else{
        obj.attachEvent('on'+type, fn)
    }
}

  • 事件解除绑定
obj.removeEventListener       不兼容9+
obj.detachEvent   兼容ie6 7 8
   解决方案:
function on(obj, type, fn){
    if(obj.removeEventListener){   
        obj.removeEventListener(type, fn, false)
    }else{
        obj.detachEvent('on'+type, fn)
    }
}整理不易,如有遗漏还请多多包涵^_^
回复

使用道具 举报

1

主题

2

帖子

3

积分

新手上路

Rank: 1

积分
3
发表于 2023-3-31 14:48:39 | 显示全部楼层
大神操作啊 这作者   真细致
回复

使用道具 举报

1

主题

3

帖子

4

积分

新手上路

Rank: 1

积分
4
发表于 2023-3-31 14:48:59 | 显示全部楼层
旭哥YYDS~
不错
回复

使用道具 举报

1

主题

4

帖子

4

积分

新手上路

Rank: 1

积分
4
发表于 2023-3-31 14:49:17 | 显示全部楼层
还的是我旭哥
[滑稽]
回复

使用道具 举报

0

主题

2

帖子

0

积分

新手上路

Rank: 1

积分
0
发表于 2023-3-31 14:49:59 | 显示全部楼层
感谢支持呐~[红心][红心]一看就是旭哥的小迷弟~~
回复

使用道具 举报

0

主题

1

帖子

0

积分

新手上路

Rank: 1

积分
0
发表于 2023-3-31 14:50:21 | 显示全部楼层
[滑稽][滑稽][滑稽]
回复

使用道具 举报

1

主题

5

帖子

4

积分

新手上路

Rank: 1

积分
4
发表于 2023-3-31 14:51:06 | 显示全部楼层
感谢支持呐~[爱]
回复

使用道具 举报

2

主题

4

帖子

7

积分

新手上路

Rank: 1

积分
7
发表于 2023-3-31 14:51:44 | 显示全部楼层
旭哥YYDS(永远单身)[滑稽]
回复

使用道具 举报

1

主题

3

帖子

3

积分

新手上路

Rank: 1

积分
3
发表于 2023-3-31 14:52:32 | 显示全部楼层
旭哥真帅!(5毛1条,括号请删除)
回复

使用道具 举报

0

主题

4

帖子

0

积分

新手上路

Rank: 1

积分
0
发表于 2023-3-31 14:53:24 | 显示全部楼层
咱班啊 ,还得是旭哥啊
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|微软交流社区

GMT+8, 2025-1-23 08:19 , Processed in 0.088596 second(s), 18 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表