Javascript解决常见浏览器兼容问题的12种方法


Posted in Javascript onJanuary 04, 2010

如果你不知道原因,不要过于担心,请研究CSS规则并查看这篇文章:使用CSS来修正一切: 20 +常见错误和修复。
如果这些也无效,您可以通过下面列出的12个javascript解决方案修复它,这样您的网页看起来就能跨越所有浏览器了!
在本文中,我们会揭开你在开发web应用是可能会遇到的12个最常见的CSS问题的javascript解决方案。

1. 自动匹配高度

Javascript解决常见浏览器兼容问题的12种方法

自从我们抛弃了基于Table的页面布局后,创建同等高度栏目或内容盒子的视觉效果已然是一个挑战。

1.1 用jQuery设置匹配高度

这个jQuery插件在同一个容器里“平衡”盒子的高度并创造一个简介的网格——几乎从可用性和性能的角度使用简单的JavaScript替代: equalHeights()函数测定一个容器里的所有同级元素同容器的高度,然后设置每个元素的最低高度为最高的元素的高度。

如何工作

equalHeights()通过循环测定指定元素的最高级别的子节点,然后设置他们的最小高度值为最高的元素的高度。

点击这里预览效果

1.2 用jQuery匹配栏目高度

jQuery的另一个可以使盒子的高度相等的插件

$(“#col1, #col2″).equalizeCols();

将如你所想的那样匹配高度

$(“#col1, #col2″).equalizeCols(“p,p”);

匹配这两卷,并在#col1或#col2(短的那个)里的P标签后面添加空白.
2. IE6 PNG透明支持

IE6以下的版本不支持png透明。使用hack,IE 5.5和6也已经可以支持,但hack并不理想的且难以使用。让我们来看看我们能做些什么来支持IE6用户 ,同时为网站的大多数访客带来最佳的透明效果。

2.1 强制IE6支持透明

IE7的是一个Dean Edwards建立的JavaScript库,以强迫MSIE(IE6,IE5)表现的像一个兼容标准的浏览器。它修复许多CSS问题并使透明PNG在IE6和IE5下正常工作,它还允许高级的CSS选择器。

点击查看预览效果
点击下载源文件

2.2. 改良iFixPng

Javascript解决常见浏览器兼容问题的12种方法

修正IE6及以下的PNG图片的问题,IMG标签和CSS背景图片都可以。这个插件是对原始iFixPng插件的一种改进。特点包括:图像或有背景图片的标签,现在支持background-position,其中包括IE浏览器的绝对定位的修正。(bottom: -1px || bottom: 0px)

点击查看预览效果
点击这里下载源文件

3. 用Javascript改变class

Javascript解决常见浏览器兼容问题的12种方法

这是一个方便的JavaScript函数,可以在当前的文件的任何元素的class由oldClass改为newClass。这是特别有用的快速的利用CSS而不是用编码改变风格。

function changeClass(oldClass, newClass) {
      var elements = document.getElementsByTagName(“*”);
      for( i = 0; i < elements.length; i++ ) {
            if( elements[i].className == oldClass ) elements[i].className = newClass;
      }
}

点击查看预览效果
点击下载源文件

4. CSS浏览器选择器

如果您可以只需键入一个特殊选择器,在这里您可以写一些JavaScript ,设置一个Class在基于当前的浏览器的名字的标签会怎么样?

Javascript解决常见浏览器兼容问题的12种方法

4.1 CSS Browser

这是一个非常小的javascript只有一行,而且不到1kb,它允许CSS选择器。它让您可以为每个操作系统和每个浏览器写具体的CSS代码。你可以写一些JavaScript ,设置Class的名字,也就是说,内容根据当前的浏览器。

点击查看预览效果
点击下载源文件

jQuery 浏览器选择器

这里有另外一个基于jQuery的非常简单的处理浏览器选择器的方法,你需要做的只是加载jQuery库文件,并添加下面的一块儿代码。

$(document).ready(function(){
$(‘html').addClass($.browser);
});

现在你可以准备你的样式,如.msie,.mozilla, .opera, .safari 或其它目标浏览器。

点击查看预览效果

5. 最小/最大 高度/宽度支持

针对CSS min-width, min-height, max-width, max-height, border-*-width, margin, 和padding 属性,这里有一些很好的jQuery修正。

5.1 jQMinMax

这是一个为没有原声的支持min-width, max-width,min-height和max-height的地方添加支持的jQuery插件。

点击查看预览效果
点击下载源文件

5.2 JSizes

这个小jQuery插件为CSS min-width, min-height, max-width, max-height, border-*-width, margin, 和padding 属性添加支持。特别是他提供一种方法来确定一个元素在那里可见。由于所有的型号的方法返回数值,所以这些也可以安全的使用在严格的DOM元素方面。

jQuery(function($) {
     var myDiv = $(‘#myDiv');

     // set margin-top to 100px and margin-bottom to 10em
     myDiv.margin({top: 100, bottom: ‘10em'});

     // displays the size of the top border in pixels
     alert(myDiv.border().top);

     // displays true if the element is visible, false otherwise
     alert(myDiv.isVisible());

     // set padding-right to 10px and margin-left to 15px using chaining
     myDiv.padding({right: 10}).margin({left: 15});
});

点击查看预览效果
点击下载源文件

6. 元素垂直/水平居中

你可能之前遇到过这个问题:水平或垂直居中某个元素。垂直居中在CSS里面相当麻烦,特别是你想支持所有主流浏览器。

Javascript解决常见浏览器兼容问题的12种方法

6.1 Center element plugin

这个插件可以使页面中的所有元素居中,垂直和水平居中采用css负margin的方法。

$(“element”).center(); //vertical and horizontal
$(“element”).center({
horizontal: false // only vertical
});

点击查看预览效果
点击下载源文件

6.2 我是怎么把一个元素垂直居中的?

在这个视频教程里, Jeffrey Jordan Way将为你展示如何使用jQuery的力量结合CSS在你的浏览器里面使一个图片垂直居中.

7. 在IE里使用Q标签

人们期望使用的Q标签而不是blockquote标签来显示引号。然而IE/Win不支持Q标签,因为这一点,大部分网站的作者选择不使用Q标签。

7.1 QinIE

当你在你的文件的头部添加这个脚本在IE浏览器里自动扫描的网页Q的标记,并正确的显示它们(包括嵌套引用) 。当(如果)IE浏览器将来支持Q标签,这个插件将会添加浏览器版本检查。

点击下载源文件

8. 增加点击目标的大小和获得更多的响应转换

Javascript解决常见浏览器兼容问题的12种方法

通过把你的所有内容放到一个可点击的标签来和单调的“read more…”链接说拜拜吧。

点击下载源文件

9. Lazy loader

Lazy loader 是一个jQuery。它可以延迟加载页面里面的图片. 在用户浏览视界(页面中可见部分)以外的图片之前,它将不会被加载。这和image preloading的作用正好相反.

点击查看预览效果
点击这里下载源文件

10. bgiframe

轻松的解决IE下的z-index的问题。

Javascript解决常见浏览器兼容问题的12种方法

点击查看预览效果
点击这里下载源文件

11. ieFixButtons

ieFixButtons 是一个修正IE6和7的<button>标签的bug的jquery插件。

点击查看预览效果
点击这里下载源文件

12. 溢出(overflow)修正

修正ie下的水平溢出。IE在溢出的元素里面显示一个滚动条,特别是如果元素里面只有一行,滚动条就会遮住这行内容。这个插件通过修改padding来修正这个问题。

Javascript解决常见浏览器兼容问题的12种方法

点击查看预览效果
点击这里下载源文件

英文原文:Using Javascript to Fix 12 Common Browser Headaches

中文翻译原文:用JAVASCRIPT修正12个常见的浏览器问题

Javascript 相关文章推荐
JavaScript中的继承之类继承
May 01 Javascript
前端js实现文件的断点续传 后端PHP文件接收
Oct 14 Javascript
js中利用cookie实现记住密码功能
Aug 20 Javascript
对Angular.js Controller如何进行单元测试
Oct 25 Javascript
jquery平滑滚动到顶部插件使用详解
May 08 jQuery
详解vue.js+UEditor集成 [前后端分离项目]
Jul 07 Javascript
AngularJS日程表案例详解
Aug 15 Javascript
JavaScript递归算法生成树形菜单
Aug 15 Javascript
javascript+html5+css3自定义弹出窗口效果
Oct 26 Javascript
vue ssr 实现方式(学习笔记)
Jan 18 Javascript
vue项目中使用vue-layer弹框插件的方法
Mar 11 Javascript
Vue中 axios delete请求参数操作
Aug 25 Javascript
javascript 模拟点击广告
Jan 02 #Javascript
javascript 多种搜索引擎集成的页面实现代码
Jan 02 #Javascript
让firefox支持IE的一些方法的javascript扩展函数代码
Jan 02 #Javascript
javascript getElementsByClassName 和js取地址栏参数
Jan 02 #Javascript
firefox插件Firebug的使用教程
Jan 02 #Javascript
firefox firebug中文入门教程 脚本之家新年特别版
Jan 02 #Javascript
Firefox+FireBug使JQuery的学习更加轻松愉快
Jan 01 #Javascript
You might like
php中通过eval实现字符串格式的计算公式
2017/03/18 PHP
javascript 有趣而诡异的数组
2009/04/06 Javascript
JavaScript写的一个DIV 弹出网页对话框
2009/08/14 Javascript
Jquery 插件开发笔记整理
2011/01/17 Javascript
JS 模态对话框和非模态对话框操作技巧汇总
2013/04/15 Javascript
js 使FORM表单的所有元素不可编辑的示例代码
2013/10/17 Javascript
qq悬浮代码(兼容各个浏览器)
2014/01/29 Javascript
JS/Jquery判断对象为空的方法
2015/06/11 Javascript
代码分析jQuery四种静态方法使用
2015/07/23 Javascript
JS实现三级折叠菜单特效,其它级可自动收缩
2015/08/06 Javascript
JavaScript iframe数据共享接口实现方法
2016/01/06 Javascript
跨域资源共享 CORS 详解
2016/04/26 Javascript
JS运动特效之完美运动框架实例分析
2018/01/24 Javascript
AnglarJs中的上拉加载实现代码
2018/02/08 Javascript
javascript中的闭包概念与用法实践分析
2019/07/26 Javascript
javascript实现视频弹幕效果(两个版本)
2019/11/28 Javascript
浅谈React中组件逻辑复用的那些事儿
2020/05/21 Javascript
Vue实现跑马灯效果
2020/05/25 Javascript
Vue解决echart在element的tab切换时显示不正确问题
2020/08/03 Javascript
Vue项目打包部署到apache服务器的方法步骤
2021/02/01 Vue.js
Python中使用urllib2防止302跳转的代码例子
2014/07/07 Python
Python两个整数相除得到浮点数值的方法
2015/03/18 Python
django将数组传递给前台模板的方法
2019/08/06 Python
Python从列表推导到zip()函数的5种技巧总结
2019/10/23 Python
Python Print实现在输出中插入变量的例子
2019/12/25 Python
python map比for循环快在哪
2020/09/21 Python
H5混合开发app如何升级的方法
2018/01/10 HTML / CSS
意大利和国际奢侈品牌购物网站:Suitnegozi.com
2021/01/15 全球购物
聚网科技C++面试笔试题
2015/09/01 面试题
超市国庆节促销方案
2014/02/20 职场文书
《识字五》教学反思
2014/03/01 职场文书
程序员求职信
2014/04/16 职场文书
2014年教师节讲话稿5篇
2014/09/10 职场文书
数据库连接池
2021/04/06 MySQL
python实现语音常用度量方法的代码详解
2021/05/25 Python
vue+spring boot实现校验码功能
2021/05/27 Vue.js