zoukankan      html  css  js  c++  java
  • javascript与CSS复习(三)

    呵呵,又弄成了三部曲,这是最后一部分,关于鼠标和浏览器本身显示上的一些属性。

    我们先来看看如何获取光标相对于整个页面的位置,因为光标位置变量x,y一般通过鼠标事件获取(如mousemove或者mousedown),下面两个通用函数,用于获取光标相对于整个页面的当前位置。

    //获取光标的水平位置
    function getX(e) {
          //通用化事件对象
          e = e || window.event;
          //先检查非IE浏览器的位置,在检查IE的位置
          return e.pageX || e.clientX + document.body.scrollLeft;
    }
    
    //获取光标的垂直位置
    function getY(e) {
          //通用化事件对象
          e = e || window.event;
          //先检查非IE浏览器的位置,在检查IE的位置
          return e.pageY || e.clientY + document.body.scrollTop;
    }
    

    像在FF中e.pageX就是在整个页面中的X坐标(包括滚动条的滚动距离), 而在IE中e.clientX表示当前显示在用户面前视图中的X坐标,还要加上document.body.scrollLeft(横向滚动条的距离)才是完整的X坐标位置。

    下面的一个概念是视口(viewport),可以看作是浏览器滚动条内的一切东西。视口还包含的部分组件是视口窗口、页面和滚动条等。

    获得页面的尺寸:

    //返回页面的高度(增加内容的时候可能会改变)
    function pageHeight() {
           return document.body.scrollHeight;
    }
    //返回页面的宽度
    function pageWidth() {
           return document.body.scrollWidht;
    }
    

    其中的scrollHeightscrollWidth(点击查阅),它们详细描述了元素的潜在宽度和高度,而不只是当前所看到的尺寸。

    接下来我们要去获取滚动条的位置,换言之页面相对于视口的顶端距离。

    //确定浏览器水平滚动位置的函数
    function scrollX() {
          //一个快捷方式,用在IE6/7的严格模式中
          var de = document.documentElement;
          //如果浏览器存在pageXOffset属性,则使用它
          return self.pageXOffset ||
          //否则,尝试获取根节点的左端滚动偏移量         
          (de && de.scrollLeft) ||
          //最后,尝试获取body元素的左端滚动偏移量
           document.body.scrollLeft;
    } 
    
    //确定浏览器垂直滚动位置的函数
    function scrollY() {
          //一个快捷方式,用在IE6/7的严格模式中
          var de = document.documentElement;
          //如果浏览器存在pageYOffset属性,则使用它
          return self.pageYOffset ||
          //否则,尝试获取根节点的顶端滚动偏移量           
          (de && de.scrollTop) ||
           //最后,尝试获取body元素的顶端滚动偏移量 
          document.body.scrollTop;
    }
    

      下面我们来看看如何移动滚动条,我们可以用scrollTo方法,它作为window对象的一个属性而存在,它带有两个参数,即x和y偏移量,可以滚动到视口指定位置,两个例子

    //如果需要滚动到浏览器的顶端,可以这么做
    window.scrollTo(0,0)
    
    //如果需要滚动到指定元素,则可以这样
    window.scrollTo(0, pageY(document.getElementById('content')));
    
    

     如果对pageY函数不熟悉了,可以往回复习下,用来获得元素在整个文档中的位置,再给出一遍,让自己也巩固下

    //获取元素的Y位置
    function pageY(elem) {
          //查看我们是否位于根元素 
          return elem.offsetParent ?
                 //如果我们能继续得到上一个元素,增加当前的偏移量并继续往上递归
                 elem.offsetTop + pageY(elem.offsetParent):
                 //否则,获取当前的偏移量
                 elem.offsetTop;
    }
    

     我们下面来学习如何获得视口(viewport)的尺寸,获取视口的尺寸就可以深入了解用户当前可以看到的内容有多少。

    //获取视口的高度
    function windowHeight() {
          //一个快捷方式,用在IE6/7的严格模式中
          var de = document.documentElement;
          //如果浏览器存在innerHeight属性,则使用它
          return self.innerHeight ||
          //否则,尝试获取根节点高度
          (de && de.clientHeight) ||
          //最后,尝试获取body元素的高度
          document.body.clientHeight;
    }
    
    //获取视口的宽度
    function windowWidth() {
          //一个快捷方式,用在IE6/7的严格模式中
          var de = document.documentElement;
          //如果浏览器存在innerWidth属性,则使用它
          return self.innerWidth ||
          //否则,尝试获取根节点宽度
          (de && de.clientWidth) ||
          //最后,尝试获取body元素的宽度
          document.body.clientWidth;
    }
    

     可能你会对innerHeight,clientHeight等属性有些疑惑,那就直接点击它,Mozilla Developer center里解释的很清楚。

    最后来讲一个比较有意思的效果,现在web前端中也很流行——"拖拽",作者没有给出具体的实现,而是引用了一个不错的js库,dom-drag.js,可以学习下高手的源码,同时介绍了好几个流行的js库,jquery也在其中。好了javascript与css的复习到这了,有什么问题欢迎留言讨论。

  • 相关阅读:
    理解TCP/IP,SOCKET,HTTP,FTP,RMI,RPC,webservic
    flyway 管理数据库版本
    【代码工具】Lombok来优雅的编码
    windows常用
    Elasticsearch-基础介绍及索引原理分析
    Zipkin和微服务链路跟踪
    【安装】Mac rabbitMQ
    数论四大定理的证明与部分应用(含算术基本定理)
    洛谷 P1306 斐波那契公约数 题解
    「SWTR-04」Sweet Round 04 游记
  • 原文地址:https://www.cnblogs.com/AndyWithPassion/p/js_css_3.html
Copyright © 2011-2022 走看看