javascript 窗口宽高滚动
//不加window IE不支持
console.info(window.screenLeft);//IE支持火狐不支持 console.info(window.screenX);//火狐支持,IE不支持 //窗口
var leftX = typeof window.screenLeft=='number'?window.screenLeft:window.screenX; var topY = typeof window.screenTop=='number'?window.screenTop:window.screenY; window.innerWidth //窗口页面大小 ie不支持 谷歌中相等 window.outerWidth //窗口页面大小 +边框 document.documentElement.clientWidth;//所有浏览器都支持 console.info(document.getElementById("bottom").clientWidth);//可视区宽度,不计算外边框,外边距,计算内边距,滚动条会减少宽度,在没有内边距和滚动条的情况下不设置宽度,IE会默认为0 document.getElementById("bottom").scrollHeight; //IE指有效高度 document.getElementById("bottom").offsetWidth; //实际大写,浏览器都兼容//增加滚动条和外边距不计算,增加内边距会计算 document.getElementById("bottom").getBoundingClientRect().top; //浏览器都支持IE默认2,2
<button id="toBottom">滚动到底部</button>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<p>111111111111111111111111111111111111111</p>
<div id="bottom">
你好谁大法师打发斯蒂芬
</div> <button id="toTop">滚动到顶部</button>
//使指定区域可见
window.onload = function(){
document.getElementById("toBottom").addEventListener("click",function(){ document.getElementById("bottom").scrollIntoView(); },false); document.getElementById("toTop").addEventListener("click",function(){
document.getElementById("toBottom").scrollIntoView(); },false); }
<!DOCTYPE HTML>
<html>
<head>
<meta charset=UTF-8>
<title>SCROLL</title>
<style type="text/css">
</style>
<script type="text/javascript">
var goToWhere = function (where)
{
var me = this;
me.site = [];
me.sleep = me.sleep ? me.sleep : 16;
me.fx = me.fx ? me.fx : 6;
clearInterval (me.interval);
var dh = document.documentElement.scrollHeight || document.body.scrollHeight;
var height = !!where ? dh : 0;
me.interval = setInterval (function ()
{
var top = document.documentElement.scrollTop || document.body.scrollTop;
var speed = (height - top) / me.fx;
if (speed === me.site[0])
{
window.scrollTo (0, height);
clearInterval (me.interval);
}
window.scrollBy (0, speed);
me.site.unshift (speed);
}, me.sleep);
};
</script>
</head>
<body>
<div style="height: 1000px; text-align: center; font-size: 200px; font-weight: bold;">5</div>
<div style="height: 1000px; text-align: center; font-size: 200px; font-weight: bold;">4</div>
<div style="height: 1000px; text-align: center; font-size: 200px; font-weight: bold;">3</div>
<div style="height: 1000px; text-align: center; font-size: 200px; font-weight: bold;">2</div>
<div style="height: 1000px; text-align: center; font-size: 200px; font-weight: bold;">1</div>
<div style="height: 1000px; text-align: center; font-size: 200px; font-weight: bold;">0</div>
<div onclick="goToWhere(0)"
style="border: 1px solid red; height: 100px; width: 15px; position: fixed; cursor: pointer; right: 10px; bottom: 150px;">返回顶部</div>
<div onclick="goToWhere(1)"
style="border: 1px solid red; height: 100px; width: 15px; position: fixed; cursor: pointer; right: 10px; bottom: 30px;">返回底部</div>
</body>
</html>
$('html, body').animate({scrollTop: $("#"+id).offset().top-20}, 200);
javascript 窗口宽高滚动的更多相关文章
- React组件自适应窗口宽高
很多时候我们需要组件能够根据窗口变化改变宽高,有时候可以使用css,有时候需要随数据调整则使用js计算. 比如说,当我们在页面中放置一个iframe时,我们希望它的宽高随着其父元素or窗口的变化而变化 ...
- iframe跨域动态设置主窗口宽高
Q:在A项目的a页面嵌入一个iframe,src是B项目的b页面,怎样让a页面的高度跟b页面的高度一样? A:解决跨域方案:增加一个A项目的c页面. 操作步骤: 一,a页面的iframe设置: 获取到 ...
- javascript 获取当前浏览器窗口宽高
获取当前浏览器窗口宽度:document.documentElement.clientWidth;获取当前浏览器窗口高度:document.documentElement.clientHeight; ...
- 原生js和jquey获取窗口宽高,滚动条,鼠标位置总结
JQuery获取浏览器窗口的可视区域高度和宽度,滚动条高度 alert($(window).height()); //浏览器时下窗口可视区域高度 alert($(document).height( ...
- Javascript:各种宽高
Javascript: IE中:document.body.clientWidth ==> BODY对象宽度document.body.clientHeight ==> BODY对象高度d ...
- JavaScript固定宽高
固定高宽: <script type="text/javascript"> if (/Android (\d+\.\d+)/.test(navigat ...
- C# 控制台程序(命令行程序)设置字体颜色,窗口宽高,光标行数
控制台程序(命令行程序)设置窗口宽度高度,如下代码: Console.WriteLine(Console.WindowHeight); Console.WriteLine(Console.Buffer ...
- JQ 获取浏览器窗口宽高
$(window).height(); // 浏览器时下窗口可视区域高度 $(document).height(); //浏览器时下窗口文档的高度 $(document.body).height(); ...
- javascript各种宽高
参考: http://www.w3cschool.cc/jsref/dom-obj-all.html http://www.cnblogs.com/wen12128/archive/2012/05/2 ...
随机推荐
- 深入理解Java String类(综合)
在Java语言了中,所有类似“ABC”的字面值,都是String类的实例:String类位于java.lang包下,是Java语言的核心类,提供了字符串的比较.查找.截取.大小写转换等操作:Java语 ...
- Android 6.0 动态权限申请注意事项
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/uana_777/article/details/54136255 Part One 权限区分 And ...
- IntelliJIdea 2016.2 使用 tomcat 8.5 调试spring的web项目时,bean被实例化两次导致timer和thread被启动了两遍的问题的解决
今天新搭建了一个spring的web项目,项目启动时会启动一个线程,线程里定时执行任务,另外还启动了一个定时器,每秒钟统计系统吞吐量等业务性能数据.但是调试的时候惊奇的发现定时器和线程均被启动了两次. ...
- jQuery - Detect value change on hidden input field
You can simply use the below function, You can also change the type element. $("input[type=hidd ...
- 11个超震撼的HTML5和纯CSS3动画源码
1.jQuery多功能手风琴个人信息菜单面板 这是一款基于jQuery的手风琴个人信息菜单面板,每一个菜单项展开后可以自定义布局,因此可以为每一个菜单项实现多功能.类似这样的多功能菜单还有jQuery ...
- 10款基于jquery的web前端动画特效
1.jQuery横向手风琴图片切换动画 之前我们为大家分享过很多款基于jQuery和CSS3的手风琴菜单和手风琴焦点图插件,比如CSS3响应式垂直手风琴菜单和jQuery横向手风琴图片展示插件.今天要 ...
- 值得从PHP转向JavaScript
1.掌握一门语言而成为爆栈工程师确实诱惑力极大 2.JavaScript 代码的语义性比 PHP 更强一些,当然语言整体特性也复杂不少,学习成本是更高的 3.JSON原生:配合MongoDB的话,从头 ...
- USB2.0学习笔记连载(一):CY7C68013特性简介
上一篇博客已经给出了整个视频板卡架构,那么对于USB接口部分需要着重理解和学习. 对于目前来说,若是利用FPGA去模拟USB2.0内核,难度还是挺大的,整个状态的收发都不好控制.现在目前都在使用桥接芯 ...
- 【转】wpf 模板选择器DataTemplateSelector及动态绑定,DataTemplate.Triggers触发器的使用
通常,如果有多个 DataTemplate 可用于同一类型的对象,并且您希望根据每个数据对象的属性提供自己的逻辑来选择要应用的 DataTemplate,则应创建 DataTemplateSelect ...
- 释放锁标记只有在Synchronized代码结束或者调用wait()。
释放锁标记只有在Synchronized代码结束或者调用wait(). 注意锁标记是自己不会自动释放,必须有通知. 注意在程序中判定一个条件是否成立时要注意使用WHILE要比使用IF要严密. WHIL ...