分享

针对各种浏览器,前端解决方案(持续更新...)

 quasiceo 2016-06-09

针对各种浏览器,前端解决方案(持续更新...)

一、head标签

  PC端

  1、在head标签中添加 <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> 

这是一个,文档兼容模式的定义。
Edge 模式告诉 ie 以最高级模式渲染文档,也就是任何 ie 版本都以当前版本所支持的最高级标准模式渲染,避免版本升级造成的影响。简单的说,就是什么版本 ie 就用什么版本的标准模式渲染
<meta http-equiv="X-UA-Compatible" content="ie=edge">

使用以下代码强制 ie 使用 Chrome Frame 渲染
<meta http-equiv="X-UA-Compatible" content="chrome=1">

提示 ie 用户安装 Google Frame
Google 官方提供了对 Google Frame 插件安装情况的检测,这里直接调用方法即可,如果检测到 IE 并未安装 Google Frame,则弹出对话框提示安装。
<script src="http://ajax./ajax/libs/chrome-frame/1/CFInstall.min.js"></script><script>CFInstall.check();</script>

最佳的兼容模式方案,结合考虑以上两种:
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">

  2、在head标签中添加<meta name="renderer" content="webkit"> 详情可参考360的这篇关于meta标签的说明文档http://se.360.cn/v6/help/meta.html

  phone 端

  1、一般会在手机网站的head标签中添加 <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">

    其中: width=device-width :表示宽度是设备屏幕的宽度; initial-scale=1.0:表示初始的缩放比例 ;minimum-scale=1.0:表示最小的缩放比例 ;maximum-scale=1.0:表示最大的缩放比例; user-scalable=yes:表示用户是否可以调整缩放比例

    这里有几篇文章可参考阅读以下:    

    http:///viewports.html
    http:///viewports2.html
    http://www./blog/2012/05/responsive_web_design.html

 

二、PNG图片在IE6下透明问题:参考 http://www./thread-297-1-1.html 所有的解决方案都在这里,本人使用PNG-24 第七种方法有效。

 介绍:我们都知道在目前所用的png图片透明解决方案基本都是使用滤镜、xpression解决的、透明gif替代。但是这些方法都有一个缺点,就是不支持CSS中backgrond-position与background-repeat。而这次的js插件使用了微软的VML语言进行绘制且不需要引入其他文件,一个小小的js就可以完美解决png图片bug就连img标签和hover伪类也可以很好的解决。

思路:
        1、首先下载此方案所用到的文件, DD_belatedPNG.zip (3.76 KB) 

        2、引入刚下载的js文件,同样由于此js只有使用IE6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有IE6的时候才调用执行此JavaScript:
        <!--[if IE 6]><script type="text/javascript" src="js/DD_belatedPNG.js"></script><![endif]-->
        3、调用函数,设置参数如下:
              DD_belatedPNG.fix("#pngImg,#pics,#picsRepeat");

              其中传入的参数为所使用png图片的标签的ID、类样式和标签名称,同样也可以按照下方这样来写
              DD_belatedPNG.fix("#content img");
              此方法则表示#content下的所有img标签透明

              如果为链接和链接的hover设置透明,那么您按照下方这么来写,在部分版本里面可以不用加入:hover直接写选择器即可,但是为了保险,建议咱们还是加上:hover:
              DD_belatedPNG.fix("#links,#link:hover");

              写到这里并且您使用过jQuery或者CSSQuery类库,那么您一定熟悉上面的这种选择方法,总之就是,在CSS中您是如何选择的元素,那么在这个js函数(方法)中传入什么,只不过多个选择的时候,使用逗号隔开即可。


        KwooShung用此方法时的小技巧:如果页面中存在很多png,DD_belatedPNG.fix();函数的参数岂不是很长?我们可以使用这种写法:
             DD_belatedPNG.fix(".pngFix,.pngFix:hover");

             如果使用上述的写法,我们的html中只需要在相对应的标签上加入class="pngFix"就行了,如果有多个类样式,按照平时的多个类样式的写法即可class="abc cbc pngFix"

             使用此方法的时候,我们每次都要加载两个js文件或者写两个<script>标签才行,这样不太好,http请求会增多,那么我们可以打开DD_belatedPNG.js文件,在尾部加入如下代码即可:
             window.onload = function()
             {
                          DD_belatedPNG.fix(".pngFix,.pngFix:hover");
             }

             这样我们只需要引入此JS,在需要透明的标签上加入class="pngFix"即可,简单 · 方便 · 快捷!


优点:
        1、CSS代码无需任何修改,按照平时的思路来写即可;
        2、无需配置;
        3、没有多余的gif图片;
        4、支持img;
        5、支持平铺;
        6、支持CSS Sprite;
        8、支持Hover等伪类;


缺点:
        1、额外加入了js文件(6.39k)和http请求,可以忽略不计;
        2、当文件载入之前,会先暂时呈现灰底;
        3、js文件过多的时候,可能会报错,导致js无法正常运行(这种情况极少出现,可以忽略不计);


使用情况:
        1、当前6种方法均不能解决问题的时候可考虑;
        2、当png图片过多的时候可考虑,因为png图片太多,使用前面的几个方法,有的会导致CSS代码冗余过多,还不如引入此文件划算;

 

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多