在 样式布局分享-基于frozen.js的移动OA 文章中,用了到第三方组件 tab.js(带菜单的横屏滑动插件),其兼容性不好,进行优化后,已兼容全平台(且支持IE6+)。javascript
一直据说过IE6~IE9浏览器的兼容性问题是深坑,此次终于有所体会,就本次优化tab.js而言,若是不对IE6~IE9进行兼容,工做量能够减小一倍。git
特此把遇到的各类浏览器兼容性问题进行汇总,但愿对你们有所帮助。github
说明:去掉字符串中的空格。web
// 如下为兼容写法 String.prototype.trim = function () { return this.replace(/^\s\s*/, '').replace(/\s\s*$/, ''); }
说明:它是由浏览器专门为动画提供的API,效果和setTimeout/setInterval相似。浏览器
// 如下为兼容写法 var rAF = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (callback) { window.setTimeout(callback, 1000 / 60); };
说明:为元素绑定事件。微信
// 如下写法能够兼容大部分状况 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; } };
说明:引起事件的DOM元素。frontend
// 如下为兼容写法 target = event.target || event.srcElement;
说明:若是事件对象的cancelable属性为true,则该方法能够取消事件的默认动做,但并不取消事件的冒泡行为。(如下为兼容方法)布局
// 如下为兼容写法 event.preventDefault ? event.preventDefault() : (event.returnValue = false);
说明:阻止事件的冒泡行为。优化
// 如下为兼容写法 event.stopPropagation ? event.stopPropagation() : (event.cancelBubble = false);
说明:鼠标在页面上的位置,从页面左上角开始,便是以页面为参考点,不随滑动条移动而变化。
// 如下为兼容写法 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);
欢迎关注微信公众号「劼哥舍」,老斯基带你飙车。