JavaScript跟随滚动条滚动的层(浮动AD效果)

VirginiaIris · 发布于 2017-01-11 · 字数3809 · 浏览 780 · 评论 0

其实这个效果在很多网站中都能见到,其主要表现为网页两侧的浮动广告。看起来感觉很难做,但其实原理是很简单的,使用定时器没0.1秒检测层的位置并将其置在指定的位置(相对于窗口)。写了一个简单的代码:

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
注意:
if (window.innerHeight) {
posX = window.pageXOffset;
posY = window.pageYOffset;
}
else if (document.documentElement && document.documentElement.scrollTop) {
posX = document.documentElement.scrollLeft;
posY = document.documentElement.scrollTop;
}
else if (document.body) {
posX = document.body.scrollLeft;
posY = document.body.scrollTop;
}
这段代码是为了兼容标准,在xhtml页面中,document.body.scrollTop始终为0,即该属性无效,因此必须用其他的属性来判断,为兼容新旧标准,应该对属性的可用性进行判断。

引用网上的一段文字:

引用

应用WEB标准会使ScrollTop属性失效!!!
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0
Transitional//EN”
“http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml”>

加上这段后,document.body.scrollTop永远等于0

body onscroll = “alert(document.body.scrollTop);”永远也不会引发。

解决办法:

使用:

document.documentElement.scrollTop

示例一:

var scrollPos;
if (typeof window.pageYOffset != ‘undefined’) {
scrollPos = window.pageYOffset;
}
else if (typeof document.compatMode != ‘undefined’ &&
document.compatMode != ‘BackCompat’) {
scrollPos = document.documentElement.scrollTop;
}
else if (typeof document.body != ‘undefined’) {
scrollPos = document.body.scrollTop;
}
alert(scrollPos);

示例二:

function WebForm_GetScrollX()
{
if (__nonMSDOMBrowser)
{
return window.pageXOffset;
}
else
{
if (document.documentElement && document.documentElement.scrollLeft)
{
return document.documentElement.scrollLeft;
}
else if (document.body)
{
return document.body.scrollLeft;
}
}
return 0;
}

————————————-
pageYOffset是netscape的
document.body.scrollTop和document.documentElement.scrollTop是ie的,但我不知道他们的真正区别,只知道documentElement.scrollTop是xhtml兼容的(我用的是strict)

本文系作者 VirginiaIris 授权问说网发表,并经问说网编辑,转载请注明出处和 本文链接

相关文章

  • 2015-12-26分享jQuery快速开发小技巧代码片段
  • 2015-12-26PNotify基于JavaScript简单易用消息提示插件
  • 2017-01-19用JavaScript实现给出的盒子的序列是否可连为一矩型
  • 2016-12-02FlyJSONP轻量级的跨域AJAX请求插件
  • 2016-03-08原生AJAX基础讲解及兼容处理
  • 2016-05-14好喜欢太有爱了!设计美味菜单的10个大招
  • 2016-05-283种方法实现网页自动刷新重新加载
  • 2016-06-06Git初始化和自定义初始目录
  • 发布评论

    为您推荐

    问说网 · 发布于 2016-01-11

    Markdown-js基于JavaScript的Markdown语法解析器

    Markdown-js是一个基于JavaScript的Markdown语法解析器,有几个选项,在这个项目,但都把Markdown到HTML的转换为一个单一的步骤…

    用JavaScript实现给出的盒子的序列是否可连为一矩型
    AustenJuliet · 发布于 2017-01-19

    用JavaScript实现给出的盒子的序列是否可连为一矩型

    by cpglkg <script>var arr=[5,10,15];function rect(arr,width){ arr.sort(fun…

    问说网 · 发布于 2015-08-08

    使用Python发送和接收Email电子邮件

    本文介绍了邮件传输的SMTP协议,并根据该协议,利用了Python的Smtplib和Email模块,完成邮件的发送和接收操作,以126邮件服务商为例,其中涉及到…

    MSVCR71.DLL文件丢失的解决方法
    问说网 · 发布于 2016-03-18

    MSVCR71.DLL文件丢失的解决方法

    今天在服务器上面安装MemCache内存缓存工具,安装时候系统提示MSVCR71.DLL文件丢失,MemCache也就是一个EXE文档,不存在MSVCR71.D…

    芒果图标psd绘制教程

    芒果细节部分较少,制作过程也比较简单。先找一幅较为完好的芒果实物图作为参考,然后找出暗部及高光部分,再慢慢渲染即可。 最终效果 1、新建一个800 * 600像…

    • 芒果图标psd绘制教程
    • 芒果图标psd绘制教程
    • 芒果图标psd绘制教程
    • 芒果图标psd绘制教程
    BillyAsa · 发布于 2016-05-17 · 浏览 959 · 评论 0
    Vincent · 发布于 2016-07-06

    类和对象

    定义 1. 类是用于描述同一类形的对象的一个抽象的概念,类中定义了这一类对象所因具有的静态属性(attibute)和动态行为(method) 2. 类可以看成一…

    POI
    Vincent · 发布于 2016-07-06

    POI

    官方网站 http://poi.apache.org/   术语 OOXML Office Open XML standards,基于XML格式的新标…

    Vincent · 发布于 2016-07-06

    SSH环境搭建

    Struts部分 web.xml中配置: <filter>     <filter-name>struts2</filter-na…

    问说网手机版

    躺着 站着 跪着轻松访问

    更多详情 关于作者

    VirginiaIris

    这个人比较懒,什么都没有填写!

    90 文章
    0 评论
    人气

    更多 热门话题

    APP界面

    关注 APP界面

    文章 41506 · 浏览 2057

    APP欣赏

    关注 APP欣赏

    文章 41427 · 浏览 1970

    APP手机界面

    关注 APP手机界面

    文章 41417 · 浏览 2001

    图片素材

    关注 图片素材

    文章 29463 · 浏览 1481

    高清图片

    关注 高清图片

    文章 26530 · 浏览 1680

    更多 推荐作者

    关注 惢碎葬爱

    文章 96 · 评论 0

    关注 怎麽继续

    文章 90 · 评论 2

    关注 溫柔的溫柔

    文章 91 · 评论 0

    关注 莪很迷茫

    文章 97 · 评论 0

    关注 籹孒不认输

    文章 94 · 评论 0

    关注 凉城梦镜

    文章 79 · 评论 0

    
    顶部 反馈 评论 底部

    意见反馈

    感谢您对问说网的支持,提出您在使用过程中遇到的问题或宝贵建议,您的反馈对我们产品的完善有很大帮助。

    您的反馈我们已收到!

    感谢您提供的宝贵意见,我们会在1-2个工作日,通过您留下的联系方式将处理结果反馈给您!