标签导航:

  如果滚动页面也是dom没有解决的一个问题。为了解决这个问题,浏览器实现了一下方法,以方便开发人员如何更好的控制页面的滚动。在各种专有方法中,html5选择了scrollintoview()作为标准方法。scrollintoview()可以在所有的html元素上调用,通过滚动浏览器窗口或某个容器元素,调用元素就可以出现在视窗中。如果给该方法传入true作为参数,或者不传入任何参数,那么窗口滚动之后会让调动元素顶部和视窗顶部尽可能齐平。如果传入false作为参数,调用元素会尽可能全部出现在视口中(可能的话,调用元素的底部会与视口的顶部齐平。)不过顶部不一定齐平.

一、scrollIntoView

html

<div>
<h2>scrollIntoView</h2>
<button>scrollIntoView(false)</button><button>scrollIntoView(true)</button><div>
<div></div>
<div>scrollIntoView(ture)元素上边框与视窗顶部齐平<span>scrollIntoView(false)元素下边框与视窗底部齐平</span>
</div>
</div>
</div>

css

       #myDiv {height: 900px;background-color: gray;

        }#roll_top {height: 900px;background-color: green;color: #FFF;font-size: 50px;position: relative;
        }#bottom {position: absolute;display: block;left: 0;bottom: 0;
        }

js

  window.onload = function () {
        document.querySelector("#roll1").onclick = function () {
            document.querySelector("#roll_top").scrollIntoView(false);
        };
        document.querySelector("#roll2").onclick = function () {
            document.querySelector("#roll_top").scrollIntoView(true);
        };
    }

二、滚动监听

html

<div>
<h2>scroll</h2>
<div>
<div>floor1</div>
<div>floor2</div>
<div>floor3</div>
<div>floor4</div>
<div>floor5</div>
</div>
<p>页面结构</p>
<div>
<div>测试1</div>
<div>测试2</div>
<div>测试3</div>
<div>测试4</div>
<div>测试5</div>
</div>
</div>

css

      .main div {height: 1000px;width: 300px;margin: 20px;background-color: #C0C0C0;
        }#nav {position: fixed;width: 100px;height: 200px;top: 40%;right: 10px;
        }#nav div {cursor: pointer;text-align: center;

        }

js

    $(function () {
        $(window).scroll(function () {//为页面添加页面滚动监听事件var wst = $(window).scrollTop(); //滚动条距离顶端值for (var i = 1; i 

全部代码

nbsp;html>h5之scrollIntoView控制页面元素滚动<div>
<h2>scrollIntoView</h2>
<button>scrollIntoView(false)</button><button>scrollIntoView(true)</button><div>
<div></div>
<div>scrollIntoView(ture)元素上边框与视窗顶部齐平<span>scrollIntoView(false)元素下边框与视窗底部齐平</span>
</div>
</div>
</div><div>
<h2>scroll</h2>
<div>
<div>floor1</div>
<div>floor2</div>
<div>floor3</div>
<div>floor4</div>
<div>floor5</div>
</div>
<p>页面结构</p>
<div>
<div>测试1</div>
<div>测试2</div>
<div>测试3</div>
<div>测试4</div>
<div>测试5</div>
</div>
</div><script>window.onload = function () {/* 如果滚动页面也是DOM没有解决的一个问题。为了解决这个问题,浏览器实现了一下方法,以方便开发人员如何更好的控制页面的滚动。
         在各种专有方法中,HTML5选择了scrollIntoView()作为标准方法。scrollIntoView()可以在所有的HTML元素上调用,
         通过滚动浏览器窗口或某个容器元素,调用元素就可以出现在视窗中。如果给该方法传入true作为参数,或者不传入任何参数,
         那么窗口滚动之后会让调动元素顶部和视窗顶部尽可能齐平。如果传入false作为参数,调用元素会尽可能全部出现在视口中(可能的话,调用元素的底部会与视口的顶部齐平。)不过顶部不一定齐平.         */document.querySelector("#roll1").onclick = function () {
            document.querySelector("#roll_top").scrollIntoView(false);
        };
        document.querySelector("#roll2").onclick = function () {
            document.querySelector("#roll_top").scrollIntoView(true);
        };
    }</script><script></script><script>$(function () {
        $(window).scroll(function () {//为页面添加页面滚动监听事件var wst = $(window).scrollTop(); //滚动条距离顶端值for (var i = 1; i < 6; i++) {             //加循环if ($("#f" + i).offset().top <= wst + 10) { //判断滚动条位置                    $(&#39;#nav div&#39;).css("background-color", "white");
                    $(".f" + i).css("background-color", "red");
                }
            }
        });
        $(&#39;#nav div&#39;).click(function () {
            $(&#39;html,body&#39;).animate({scrollTop: $("#" + this.className).offset().top}, 500);//          $("#" + this.className)[0].scrollIntoView(true);//h5 scrollIntoView()});
    });</script>
View Code