zoukankan      html  css  js  c++  java
  • 兼容低版本浏览器的一些方法

    • 页面滚动的兼容方法

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            body {
                height: 3000px;
            }
        </style>
    </head>
    <body>
    
    </body>
    </html>
    <script>
    
        window.onscroll = function () {
            document.title = scroll().top;
        }
    
        /*正常浏览器(除了ie678之外的浏览器)
         window.pageYOffset
         已经声明DTD(标准模式)
         document.documentElement.scrollTop
         未声明 DTD(怪异模式)
         document.body.scrollTop*/
    
    
    
        //这个方法可以给调用者提供 页面被卷去的top值和left值
        function scroll() {
            if (window.pageYOffset != null) {
                return {
                    "top": window.pageYOffset,
                    "left": window.pageXOffset
                };
            } else if (document.compatMode == "CSS1Compat") {
                //说明是标准模式 有DTD
                return {
                    "top": document.documentElement.scrollTop,
                    "left": document.documentElement.scrollLeft
                };
            } else {
                return {
                    "top": document.body.scrollTop,
                    "left": document.body.scrollLeft
                };
            }
        }
    
    </script>
    • 网页可视区client方法

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body>
    
    </body>
    </html>
    <script>
    
        window.onresize = function () {
            document.title = client().width;
        }
    
        /*正常浏览器(包括IE9+)
         window.innerWidth
         标准模式(包括IE9-)
         document.documentElement.clientWidth
         怪异模式
         document.body.clientWidth*/
    
        //返回一个对象 如果用可视区的宽度 就.width 如果用高度就 .height
        function client() {
            if (window.innerWidth != null) {
                return {
                    "width": window.innerWidth,
                    "height": window.innerHeight
                }
            } else if (document.compatMode == "CSS1Compat") {
                //标准模式
                return {
                    "width": document.documentElement.clientWidth,
                    "height": document.documentElement.clientHeight
                }
            } else {
                return {
                    "width": document.body.clientWidth,
                    "height": document.body.clientHeight
                }
            }
        }
    
    
    </script>
    •  兼容ie6、7、8获取鼠标的坐标方法

    function (event) {
            var event = event || window.event;
    
            //event.clientX//相对于客户端的位置
            //event.pageX//相对于页面的位置
            //event.screenX//相对于屏幕的位置
    
            var pageX = event.pageX || event.clientX + document.documentElement.scrollLeft;
            var pageY = event.pageY || event.clientY + document.documentElement.scrollTop;
        }
    •  阻止事件冒泡

    var event = event || window.event;
            if (event && event.stopPropagation) {//短路表达式
                //说明是正常浏览器
                event.stopPropagation();
            } else {
            //兼容ie678
                event.cancelBubble = true;
            }
    •  事件目标兼容性 

      targetId(排除事件触发案例)

    返回当前事件对象的id

    火狐谷歌等 event.target.id

    IE678      event.srcElement.id

     var targetId = event.target ? event.target.id : event.srcElement.id;

     

  • 相关阅读:
    随笔和文章的区别
    02. 什么是 SOA?
    GOF 23种设计模式(Patterns in Java)
    ASP.NET MVC: how to include <span> in link from Html.ActionLink?
    Head First 02.观察者模式(Observer)
    ActionResult types in MVC2
    探索推荐引擎内部的秘密,第 1 部分: 推荐引擎初探
    Head First 01.策略模式(Strategy Pattern)
    SOA实施:不能忽略商业价值
    nmon analyser——生成 AIX 性能报告的免费工具
  • 原文地址:https://www.cnblogs.com/goweb/p/5484173.html
Copyright © 2011-2022 走看看