web前端 js测试浏览器的类型及版本

ie的兼容是个大问题,有时候我们通过各种方法修改调试,但是效果并不理想,所以我们可以采取一些暴力的手段,直接测试出浏览器的版本,然后用js强行更改!!

<script>
    function myBrowser(){
        var userAgent = navigator.userAgent; //取得浏览器的userAgent字符串
        var isOpera = userAgent.indexOf("Opera") > -1; //判断是否Opera浏览器
        var isIE = userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1 && !isOpera; //判断是否IE浏览器
        var isFF = userAgent.indexOf("Firefox") > -1; //判断是否Firefox浏览器
        var isSafari = userAgent.indexOf("Safari") > -1; //判断是否Safari浏览器
        if (isIE) {
            var IE5 = IE55 = IE6 = IE7 = IE8 = false;
            var reIE = new RegExp("MSIE (\\d+\\.\\d+);");
            reIE.test(userAgent);
            var fIEVersion = parseFloat(RegExp["$1"]);
            IE55 = fIEVersion == 5.5;
            IE6 = fIEVersion == 6.0;
            IE7 = fIEVersion == 7.0;
            IE8 = fIEVersion == 8.0;
            if (IE55) {
                return "IE55";
            }
            if (IE6) {
                return "IE6";
            }
            if (IE7) {
                return "IE7";
            }
            if (IE8) {
                return "IE8";
            }
        }//isIE end
        if (isFF) {
            return "FF";
        }
        if (isOpera) {
            return "Opera";
        }
    }//myBrowser() end
    //以下是调用上面的函数
    if (myBrowser() == "FF") {
//        alert("我是 Firefox");
    }
    if (myBrowser() == "Opera") {
//        alert("我是 Opera");
    }
    if (myBrowser() == "Safari") {
//        alert("我是 Safari");
    }
    if (myBrowser() == "IE55") {
//        alert("我是 IE5.5");
    }
    if (myBrowser() == "IE6") {
//        alert("我是 IE6");
    }
    if (myBrowser() == "IE7") {
//        alert("我是 IE7");
    }
    if (myBrowser() == "IE8") {
//        alert("我是 IE8");
    }
</script>

代码经过测试可以直接复制粘贴!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Web前端开发中,浏览器兼容性是一个常见的挑战。不同的浏览器实现了不同的标准和规范,因此相同的代码在不同的浏览器上可能会有不同的表现,甚至无法正常工作。 为了解决浏览器兼容性问题,前端开发者需要注意不同浏览器的差异性,并采用相应的解决方法来保证页面在各种浏览器中能够正确地展示和运行。以下是一些常见的解决方法和工具: 1. 使用polyfill库:Polyfill是一种JavaScript代码,用于在旧版本浏览器中实现新的Web标准和API。通过使用polyfill库,开发者可以在不支持某些功能的浏览器上模拟这些功能,从而提高兼容性。 2. 使用CSS hack:CSS hack是一种通过特定的CSS代码来针对不同浏览器的差异性进行样式修复的方法。通过使用不同的CSS hack,开发者可以针对不同浏览器应用不同的样式规则,从而解决兼容性问题。 3. 使用媒体查询:媒体查询是一种CSS技术,用于根据设备的特性(如屏幕宽度、设备类型等)来应用不同的样式规则。通过使用媒体查询,开发者可以根据不同设备的特性来调整页面的布局和样式,从而提高兼容性。 4. 使用特定的前缀:某些CSS属性和JavaScript API在不同浏览器中可能存在不同的前缀。通过在代码中添加特定的前缀,开发者可以确保这些属性和API在不同浏览器中正常工作。 5. 使用兼容性检测工具:有许多兼容性检测工具可以帮助开发者发现和解决兼容性问题。例如,Can I use是一个广泛使用的兼容性查询工具,可以查看不同浏览器对特定功能的支持情况。另外,还有一些在线工具和浏览器插件可以帮助开发者进行兼容性测试和调试。 总之,通过注意浏览器的差异性,并采用相应的解决方法和工具,开发者可以有效地解决Web前端浏览器兼容性问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值