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;
}

其中的scrollHeight和scrollWidth(点击查阅),它们详细描述了元素的潜在宽度和高度,而不只是当前所看到的尺寸。
接下来我们要去获取滚动条的位置,换言之页面相对于视口的顶端距离。


代码如下:

//确定浏览器水平滚动位置的函数
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的复习到这了,有什么问题欢迎留言讨论。

(0)

相关推荐

  • javascript与CSS复习(二)

    visibility:在切换元素可见性的同时会保持元素在普通流中的位置和空间.它有两个值:visible(默认的)和hidden(不可见的), 例如: 复制代码 代码如下: <p>Hello <b>John</b>, how are you today?</p> 浏览器中是:Hello John, how are you today? 接着我们把John所在b的visibility设置为hidden后,就会变成这样 Hello , how are you t

  • javascript与CSS复习(《精通javascript》)

    如:elem.style.height 或者 elem.style.height = '100px', 这里要注意的是设置任何几何属性必须明确尺寸单位(如px),同时任何几何属性返回的是表示样式的字符串而非数值(如'100px'而非100).另外像elem.style.height这样的操作,也能获取元素style属性中设置的样式值,如果你把样式统一放在css文件中,上述方法只会返回一个空串.为了获取元素真实.最终的样式,书中给出了一个函数 复制代码 代码如下: //get a style pr

  • javascript与CSS复习(三)

    我们先来看看如何获取光标相对于整个页面的位置,因为光标位置变量x,y一般通过鼠标事件获取(如mousemove或者mousedown),下面两个通用函数,用于获取光标相对于整个页面的当前位置. 复制代码 代码如下: //获取光标的水平位置 function getX(e) { //通用化事件对象 e = e || window.event; //先检查非IE浏览器的位置,在检查IE的位置 return e.pageX || e.clientX + document.body.scrollLeft

  • 多浏览器兼容的动态加载 JavaScript 与 CSS第1/2页

    在介绍ensure内部的实现之前,让我们先来看看其功能: ensure({ html: "popup.html", javascript: "popup.js", css: "popup.css" }, function() { Popup.show("hello world"); } ); 在这段代码中,ensure首先会确保popup.html.popup.js.popup.css这3个文件的加载,如果都没加载过ensur

  • Javascript基础回顾之(三) js面向对象

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者那里的一知半解,所以决定先花一些时间整理一下这些基础知识和大家分享. 后面会附上培训用的PPT.刚开始是打算写一篇的,但是后来写着写着就发现越来越多,所以决定还是写一个系列吧.本系列所有内容都是涉及Javascript基础的,没有时髦的玩意儿,但是我相信这些基础的东西会有助于你理解那些有趣的东西的.

  • JavaScript遍历数组的三种方法map、forEach与filter实例详解

    本文实例讲述了JavaScript遍历数组的三种方法map.forEach与filter.分享给大家供大家参考,具体如下: 前言 近一段时间,因为项目原因,会经常在前端对数组进行遍历.处理,JS自带的遍历方法有很多种,往往不加留意,就可能导致知识混乱的现象,并且其中还存在一些坑.前端时间在ediary中总结了js原生自带的常用的对数组遍历处理的方法,分别为:map.forEach.filter,在讲解知识点的同时,会类比相识的函数进行对比,这样会有助于思考方法的利与弊. 一.Js自带的map()

  • javascript函数命名的三种方式及区别介绍

    javascript函数命名的三种方式及区别介绍 第一 复制代码 代码如下: function fn(val1,val2) { alert(val1+val2); } fn(1,2); 第二 复制代码 代码如下: var fn=function() { alert(val1+val2); } fn(1,2); 第三 复制代码 代码如下: var fn=new Function("alert(val1+val2)"); fn(1,2); 上面三种方式逻辑上是等价的,但是还是有点小区别:区

  • 你未必知道的JavaScript和CSS交互的5种方法

    随着浏览器不断的升级改进,CSS和JavaScript之间的界限越来越模糊.本来它们是负责着完全不同的功能,但最终,它们都属于网页前端技术,它们需要相互密切的合作.我们的网页中都有.js文件和.css文件,但这并不意味着CSS和js是独立不能交互的.下面要讲的这五种JavaScript和CSS共同合作的方法你也许未必知道! 用JavaScript获取伪元素(pseudo-element)属性 大家都知道如何通过一个元素的style属性获取它的CSS样式值,但能获取伪元素(pseudo-eleme

  • JavaScript事件处理的方式(三种)

    最近这段时间因为每天要修改网站,为网站做特效,所以看了很多的js接触事件,自己只会使用一小部分,有时用的时候也比较混乱,现在系统的整理了一下,特此分享到我们平台供大家参考下! 一.什么是JavaScript事件? 事件(Event)是JavaScript应用跳动的心脏,也是把所有东西粘在一起的胶水,当我们与浏览器中Web页面进行某些类型的交互时,事件就发生了. 事件可能是用户在某些内容上的点击.鼠标经过某个特定元素或按下键盘上的某些按键,事件还可能是Web浏览器中发生的事情,比如说某个Web页面

  • ASP.NET MVC Bundles 用法和说明(打包javascript和css)

    在网页中,我们经常需要引用大量的javascript和css文件,在加上许多javascript库都包含debug版和经过压缩的release版(比如jquery),不仅麻烦还很容易引起混乱,所以ASP.NET MVC4引入了Bundles特性,使得我们可以方便的管理javascript和css文件. 原来,我们引用css和javascript文件我们需要这样一个一个的引用: 复制代码 代码如下: <scriptsrc="~/Scripts/jquery-1.8.2.js">

随机推荐