javascript与CSS复习(三)

所属分类: 网络编程 / JavaScript 阅读数: 704
收藏 0 赞 0 分享
我们先来看看如何获取光标相对于整个页面的位置,因为光标位置变量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的复习到这了,有什么问题欢迎留言讨论。

更多精彩内容其他人还在看

js实现图片上传预览原理分析

这篇文章主要为大家详细介绍了js实现图片上传预览的原理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Angular限制input框输入金额(是小数的话只保留两位小数点)

最近做项目遇到这样的需求输入框要求输入金额,只能输入数字,可以是小数,必须保留小数点后两位。下面分为两部分代码给大家介绍实现代码,需要的的朋友参考下吧
收藏 0 赞 0 分享

详解vue-cli + webpack 多页面实例配置优化方法

本篇文章主要介绍了详解vue-cli + webpack 多页面实例配置优化方法,具有一定的参考价值,有兴趣的可以了解一下
收藏 0 赞 0 分享

详解React-Native解决键盘遮挡问题(Keyboard遮挡问题)

本篇文章主要介绍了React-Native解决键盘遮挡问题(Keyboard遮挡问题),具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

JavaScript反弹动画效果的实现代码

本文通过实例代码给大家介绍了js反弹动画效果的实现代码,需要的朋友参考下吧
收藏 0 赞 0 分享

解决vue2.x中数据渲染以及vuex缓存的问题

本篇文章主要介绍了vue2.x中请求之前数据显示以及vuex缓存的问题,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

jsonp跨域请求详解

这篇文章主要为大家详细介绍了jsonp跨域请求的相关资料,激活了所有接口支持浏览器跨域请求的封装,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

解决vue里碰到 $refs 的问题的方法

本篇文章主要介绍了解决vue里碰到 $refs 的问题的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

js自定义弹框插件的封装

这篇文章主要为大家详细介绍了js自定义弹框插件的简单封装,自己封装一个弹框插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

深入理解vue $refs的基本用法

本篇文章主要介绍了深入理解vue $refs的基本用法 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享
查看更多