js实现淘宝固定侧边栏

 更新时间:2022年07月03日 13:58:05   作者:阿旋要毕业~  
这篇文章主要为大家详细介绍了js实现淘宝固定侧边栏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了js实现淘宝固定侧边栏的具体代码,供大家参考,具体内容如下

1.实现效果:

当页面运行到banner区域时,右边侧边栏改为固定定位,当页面运行到主体区域时,右边侧边栏显示返回到顶部。

2.思路:

(1)给document加scroll事件。

(2)获取页面被卷去的部分用window.pageYOffset.

(3)不断判断页面滚动了多少。计算右边侧边栏应该待的位置。

3.代码:

pink老师用了固定定位fixed(固定定位是相对于窗口的距离),我做的还是用绝对定位(绝对定位是相对于父元素来说的,即document),都是可以实现的。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .top {
            width: 80%;
            height: 200px;
            background-color: pink;
        }
        .banner {
            width: 80%;
            height: 400px;
            background-color: aquamarine;
        }
        .main {
            width: 80%;
            height: 800px;
            background-color: red;
        }
        .foot {
            width: 80%;
            height: 400px;
            background-color:blanchedalmond;
        }
        .lan {
            position: absolute;
            right:10%;
            top:400px;
            width: 80px;
            height: 80px;
            background-color: cadetblue;
        }
    </style>
</head>
<body>
    <div class="top">头部区域</div>
    <div class="banner">banner区域</div>
    <div class="main">头部区域</div>
    <div class="foot">尾部区域</div>
    <div class="lan"></div>
    <script>
        var lan = document.querySelector('.lan');
        document.addEventListener('scroll', function() {
            console.log('jkjkkj');
            var top = window.pageYOffset;
            if(top  > 200) {
                // 改为固定定位。
                var topp = 400-200 + top;
                lan.style.top = topp+'px';
                if(top > 600) {
                    lan.innerHTML = '返回顶部';
                } else {
                    lan.innerHTML = '';
                }
 
            } else {
                lan.style.top = 400+'px';
                lan.innerHTML = '';
            }
        })
    </script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • window.print()打印html网页的两种方法实现

    window.print()打印html网页的两种方法实现

    本文主要介绍了window.print()打印html网页的两种方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • js实现简单的拖拽效果

    js实现简单的拖拽效果

    这篇文章主要为大家详细介绍了js实现简单的拖拽效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 如何获取TypeScript的声明文件.d.ts

    如何获取TypeScript的声明文件.d.ts

    这篇文章主要介绍了如何获取TypeScript的声明文件.d.ts 的相关知识,非常不错,具有参考借鉴价值,需要的朋友参考下
    2018-05-05
  • js 解析 JSON 数据简单示例

    js 解析 JSON 数据简单示例

    这篇文章主要介绍了js 解析 JSON 数据的方法,结合简单实例形式分析了js 解析 JSON 格式数据的相关操作技巧与注意事项,需要的朋友可以参考下
    2020-04-04
  • 浅谈JavaScript正则表达式分组匹配

    浅谈JavaScript正则表达式分组匹配

    一个正则表达式要如何书写才能同时匹配这两个数字呢?简单的字符表达式当然无法完成了,这个时候我们就可以定义一个字符集合(字符类)来进行匹配。这就是分组匹配了
    2015-04-04
  • JavaScript Proxy基本用法详解

    JavaScript Proxy基本用法详解

    这篇文章主要介绍了JavaScript Proxy基本用法,Proxy对象用于创建一个对象的代理,从而实现基本操作的拦截和自定义,如属性查找、赋值、枚举、函数调用等
    2022-12-12
  • 前端强大的图片预览组件Viewer.js使用方法

    前端强大的图片预览组件Viewer.js使用方法

    这篇文章主要给大家介绍了关于前端强大的图片预览组件Viewer.js使用方法的相关资料,Viewer.js是一款强大的图片查看器,虽然简单且易上手,但是却并不影响其在图片查看方面的强大功能,同时这款优秀的插件配置操作起来也非常的方便,需要的朋友可以参考下
    2024-01-01
  • layui--select使用以及下拉框实现键盘选择的例子

    layui--select使用以及下拉框实现键盘选择的例子

    今天小编就为大家分享一篇layui--select使用以及下拉框实现键盘选择的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • JavaScript常见错误:“无法读取未定义的属性”的原因及解决方案

    JavaScript常见错误:“无法读取未定义的属性”的原因及解决方案

    本文将深入探讨“无法读取未定义的属性”这一常见JavaScript错误,分析其成因,提供详细的解决方案和最佳实践,帮助开发者有效地预防和修复此类问题,感兴趣的小伙伴跟着小编一起来看看吧
    2024-12-12
  • 解析element-ui中upload组件传递文件及其他参数的问题

    解析element-ui中upload组件传递文件及其他参数的问题

    这篇文章主要介绍了element-ui中upload组件如何传递文件及其他参数,分析一下我使用element-ui遇到的问题以及解决方法,需要的朋友可以参考下
    2021-11-11

最新评论