論如何用js實現京東樓梯效果(很多bug批評改正)

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
*{
text-decoration: none;
}
body,html{
margin: 0;
padding: 0;
}
div{
width: 500px;
height: 500px;
margin: 0 auto;
border: 1px solid black;
text-align: center;
font-size: 50px;
line-height: 500px;
}
#div1{
position: fixed;
right: 100px;
top: 0px;
z-index: 200;
width: 152px;
height: 700px;
border: none;
}
#div1 a{
width: 150px;
height: 80px;
border: 1px solid black;
display: flex;
}
#div1 a:hover{
background: #B3DAF9;
}
#header{
width: 100%;
height: 500px;
text-align: center;
line-height: 500px;
background: forestgreen;
display: block;
}
#footer{
width: 100%;
height: 500px;
background: blueviolet;
text-align: center;
line-height: 500px;
display: block;
}
</style>
</head>

<body>
    <p id="header">
            頭部
    </p>
    <div style="background: saddlebrown;" class="list">1</div>
    <div style="background: firebrick;" class="list">2</div>
    <div style="background: seagreen;" class="list">3</div>
    <div style="background: navy;" class="list">4</div>
    <div style="background: aqua;" class="list">5</div>
    <div style="background: pink;" class="list">6</div>
    <p id="footer">
        底部
    </p>
    
    <p id="div1">
        <a href="##">1</a>
        <a href="##">2</a>
        <a href="##">3</a>
        <a href="##">4</a>
        <a href="##">5</a>
        <a href="##">6</a>
        <a href="##">置頂</a>
    </p>
</body>
<script type="text/javascript">
    var odiv = document.querySelectorAll(".list")
    var pp   = document.getElementById("#div1")
    var oas  = document.getElementsByTagName("a");//獲取所有a
    time = null; //定義一個時間為空
    
    for(var i = 0 ; i<oas.length ; i++){
        oas[i].index = i;//把下標付給i
        oas[i].onclick = function(){
            console.log(this.index)
            index = this.index//把他的index付給index
            if(document.body.scrollTop<odiv[index].offsetTop){
            //如果卷起的高度小于你點的某一個div的offsettop值,說明你的某個div在可視區域下
                time = setInterval(function(){//設定定時器
                    document.body.scrollTop+=10//讓scrollTop值一直變大,也就是往下,它下offsetTop上
                    if(document.body.scrollTop<odiv[index].offsetTop){//如果他倆相比不在成立
                        document.body.scrollTop = document.body.scrollTop//就讓scrollTop=它的本身
                    }else{
                        clearInterval(time)//清除定時器
                    }
                })
            }else if(document.body.scrollTop>odiv[index].offsetTop){
            //如果卷起的高度大于你點的某一個div的offsettop值,說明你的某個div在可視區域上,于上相反    
                time = setInterval(function(){
                    document.body.scrollTop-=10
                    if(document.body.scrollTop>odiv[index].offsetTop){
                        document.body.scrollTop = document.body.scrollTop
                    }else{
                        clearInterval(time)
                    }
            })
        }
    }
        oas[6].onclick = function(){//單獨點擊第七個a標簽
            console.log(this.index)//打印一下看看
            time = setInterval(function(){
                document.body.scrollTop-=10//這里的- = 就是向上
                if(document.body.scrollTop>=1){
                    document.body.scrollTop = document.body.scrollTop
                }else{
                    clearInterval(time)
                }
            })
        }
    }
</script>

</html>

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 1. tab列表折疊效果 html: 能源系統事業部 崗位名稱: 工作地點 崗位名...
    lilyping閱讀 1,891評論 0 1
  • 不會用代碼框,所以看著有些亂套,,,,html部分 <!DOCTYPE html> 迅雷看看 ...
    這就是個帥氣的名字閱讀 1,560評論 0 0
  • 深入理解傅里葉變換Mar 12, 2017 這原本是我在知乎上對傅立葉變換、拉普拉斯變換、Z變換的聯系?為什么要進...
    價值趨勢技術派閱讀 5,810評論 2 2
  • 多少次拿起電話 卻不知道打給誰 多少個深夜想起她 卻又深知她不可能會聽見 在別人面前儼然我早已是個大人了 而在她哪...
    琴汐閱讀 2,096評論 0 1
  • 有一種心情 是河岸邊 斜坡上 不經意間長出的小草 遠看 幽幽的 有意無意的肆意滋生 悄悄地 近了 緩緩地踏上去 柔...
    曰日如歌閱讀 251評論 0 4