样式布局分享-基于frozen.js的移动OA 文章中,用了到第三方组件 tab.js(带菜单的横屏滑动插件),其兼容性很差,进行优化后,已兼容全平台(且支持IE6+)。

一直听说过IE6IE9浏览器的兼容性问题是深坑,这次终于有所体会,就本次优化tab.js而言,如果不对IE6IE9进行兼容,工作量可以减少一倍。

特此把遇到的各种浏览器兼容性问题进行汇总,希望对大家有所帮助。

trim(不支持IE6~IE9)

说明:去掉字符串中的空格。

// 以下为兼容写法
String.prototype.trim = function () {
return this.replace(/^\s\s*/, '').replace(/\s\s*$/, '');
}

requestAnimationFrame(不支持IE6~IE9)

说明:它是由浏览器专门为动画提供的API,效果和setTimeout/setInterval类似。

// 以下为兼容写法
var rAF = window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.oRequestAnimationFrame ||
window.msRequestAnimationFrame ||
function (callback) { window.setTimeout(callback, 1000 / 60); };

addEventListener (不支持IE)

说明:为元素绑定事件。

// 以下写法可以兼容大部分情况
var addHandler = function(el, type, handler, args) {
if (el.addEventListener) {
el.addEventListener(type, handler, false);
} else if (el.attachEvent) {
el.attachEvent('on' + type, handler);
} else {
el['on' + type] = handler;
}
};
var removeHandler = function(el, type, handler, args) {
if (el.removeEventListener) {
el.removeEventListener(type, handler, false);
} else if (el.detachEvent) {
el.detachEvent('on' + type, handler);
} else {
el['on' + type] = null;
}
};

event.target (不支持IE6~IE9)

说明:引发事件的DOM元素。

// 以下为兼容写法
target = event.target || event.srcElement;

event.preventDefault (不支持IE6~IE9)

说明:如果事件对象的cancelable属性为true,则该方法可以取消事件的默认动作,但并不取消事件的冒泡行为。(以下为兼容方法)

// 以下为兼容写法
event.preventDefault ? event.preventDefault() : (event.returnValue = false);

event.stopPropagation(不支持IE6~IE9)

说明:阻止事件的冒泡行为。

// 以下为兼容写法
event.stopPropagation ? event.stopPropagation() : (event.cancelBubble = false);

event.touches.pageX(不支持IE6~IE9)

说明:鼠标在页面上的位置,从页面左上角开始,即是以页面为参考点,不随滑动条移动而变化。

// 以下为兼容写法
var touches = e.touches ? e.touches[0] : e;
var pageX = (touches.pageX) ? touches.pageX : e.clientX + (document.documentElement.scrollLeft ? document.documentElement.scrollLeft : document.body.scrollLeft);
var pageY = (touches.pageY) ? touches.pageY : e.clientY + (document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop);

欢迎关注微信公众号「劼哥舍」,老斯基带你飙车。

最新文章

  1. Asp.net 设置GridView自适应列宽不变形
  2. Bootstrap JavaScript插件
  3. Linux教程:Bash技巧,让chmod只修改某个目录下文件夹或者文件的权限
  4. 用PHP抓取淘宝商品的用户晒单评论+图片实例
  5. oracle远程连接配置
  6. Python PIL库之Image注解(API)
  7. 常用aliyun公共资源列表
  8. 获取表空间的语句 以及 建表和索引的ddl
  9. shell 字符串
  10. python数据类型:序列(字符串,元组,列表,字典)
  11. SQL语句题
  12. 使用ML.NET + Azure DevOps + Azure Container Instances打造机器学习生产化
  13. python中如何对待易过期的cookies
  14. js获取非行间样式/写入样式(行间)
  15. spring 自己创建配置类
  16. 从小白到区块链工程师:第一阶段:Go语言的HelloWorld初始(2)
  17. solr 打分和排序机制(转载)
  18. zookeeper基础知识整理
  19. js操作符类型转换
  20. Postman—使用数据文件

热门文章

  1. 对‘pthread_create’未定义的引用
  2. Java中对象的三种状态
  3. 第五章 Logistic回归
  4. ASP.net+SQL server2008简单的数据库增删改查 VS2012
  5. 在EasyUI中统一判断是否有选中行,如果有则将选中行数据传入回调函数
  6. sql server数据库主键自增一插入特定值
  7. iOS 生成.a文件
  8. hdu2309ICPC Score Totalizer Software
  9. error LNK2019: 无法解析的外部符号 "public:
  10. 2015.4.16-SQL-内连接与外连接