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

VirginiaIris · 发布于 2017-01-11 · 字数3809 · 浏览 811 · 评论 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 授权问说网发表,并经问说网编辑,转载请注明出处和 本文链接

相关文章

  • 2017-01-19用JavaScript实现给出的盒子的序列是否可连为一矩型
  • 2016-04-02Memcache内存缓存的未授权访问漏洞
  • 2016-05-14真是太强大了!高效输出移动app产品原型
  • 2016-05-15酷比了!Whats APP黑色版界面设计欣赏
  • 2016-05-16搞定这10招!助你成功转型自由职业
  • 2016-05-17芒果图标psd绘制教程
  • 2016-06-24分享常用响应式Web UI开发框架
  • 2016-06-30ESLint开源的JavaScript和JSX验证工具
  • 发布评论

    为您推荐

    问说网 · 发布于 2016-12-02

    FlyJSONP轻量级的跨域AJAX请求插件

    FlyJSONP是一个JavaScript库,用于实现跨域GET和POST请求服务,支持JSONP,并取得一个JSON格式的数据响应,这个Library具有易于…

    问说网 · 发布于 2016-04-02

    Memcache内存缓存的未授权访问漏洞

    Memcache是一套常用的key-value缓存系统,由于它本身没有权限控制模块,所以开放在外网的Memcache服务很容易被攻击者扫描发现,通过命令交互可直…

    推荐三款Photoshop常用的辅助插件

    给大家介绍几款Photoshop常用的辅助插件,一个是配色工具Adobe kuler,一个是参考线工具guideguide,最后一个是标记软件Markman,在…

    • 推荐三款Photoshop常用的辅助插件
    • 推荐三款Photoshop常用的辅助插件
    • 推荐三款Photoshop常用的辅助插件
    • 推荐三款Photoshop常用的辅助插件
    问说网 · 发布于 2016-04-17 · 浏览 1130 · 评论 0
    问说网 · 发布于 2016-04-20

    PySpreadsheet基于Python为Node创建的XLSX表格插件

    PySpreadsheet是一个高性能的表格创建和读取解析插件,专为Node.js设计,基于Python开源软件,PySpreadsheet能够读取和创建Exc…

    问说网 · 发布于 2016-12-02

    Response JS创建高性能的支持移动设备的网站

    Response JS 是一个轻量级的 jQuery 插件,用来创建高性能的支持移动设备的网站。它提供了一套语法用来根据不同的设备环境动态替换HTML代码。例如…

    Photoshop制作绿色透明导航设计讲解

    透明物体是通过背景进行参照,体现出质感。而本例里是讲解Photoshop制作绿色透明导航设计,如果背景太亮,会导致对比不明显。

    • Photoshop制作绿色透明导航设计讲解
    • Photoshop制作绿色透明导航设计讲解
    • Photoshop制作绿色透明导航设计讲解
    • Photoshop制作绿色透明导航设计讲解
    KellyMatthew · 发布于 2016-05-22 · 浏览 827 · 评论 0
    问说网 · 发布于 2016-06-02

    详解C语言中Volatile关键字的使用

    Volatile提醒编译器它后面所定义的变量随时都有可能改变,因此编译后的程序每次需要存储或读取这个变量的时候,都会直接从变量地址中读取数据。

    问说网 · 发布于 2016-06-24

    Gridpak响应式轻量级Web开发框架

    Gridpak 的目的是实现了响应式的 Web 页面设计,提高工作流程,节省了时间。通过生成PNG图像,CSS和JavaScript,让 Gridpak 创建响…

    问说网手机版

    躺着 站着 跪着轻松访问

    更多详情 关于作者

    VirginiaIris

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

    90 文章
    0 评论
    人气

    更多 热门话题

    APP界面

    关注 APP界面

    文章 41506 · 浏览 3038

    APP欣赏

    关注 APP欣赏

    文章 41427 · 浏览 2813

    APP手机界面

    关注 APP手机界面

    文章 41417 · 浏览 2925

    图片素材

    关注 图片素材

    文章 29463 · 浏览 2346

    高清图片

    关注 高清图片

    文章 26530 · 浏览 2546

    更多 推荐作者

    关注 秋天的孤寂

    文章 99 · 评论 0

    关注 溫柔的溫柔

    文章 91 · 评论 0

    关注 走了留下什么

    文章 110 · 评论 0

    关注 莪很迷茫

    文章 97 · 评论 0

    关注 流浪的脚步

    文章 86 · 评论 0

    关注 籹孒不认输

    文章 94 · 评论 0

    
    顶部 反馈 评论 底部

    意见反馈

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

    您的反馈我们已收到!

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