zoukankan      html  css  js  c++  java
  • h5之scrollIntoView控制页面元素滚动

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

    一、scrollIntoView

    html

    <div>
        <h2>scrollIntoView</h2>
        <button id="roll1">scrollIntoView(false)</button>
        <button id="roll2">scrollIntoView(true)</button>
    
        <div>
            <div id="myDiv"></div>
            <div id="roll_top">
                scrollIntoView(ture)元素上边框与视窗顶部齐平
                <span id="bottom">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 id="nav">
            <div class="f1">floor1</div>
            <div class="f2">floor2</div>
            <div class="f3">floor3</div>
            <div class="f4">floor4</div>
            <div class="f5">floor5</div>
        </div>
        <p>
            页面结构
        </p>
        <div class="main">
            <div id="f1">测试1</div>
            <div id="f2">测试2</div>
            <div id="f3">测试3</div>
            <div id="f4">测试4</div>
            <div id="f5">测试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 < 6; i++) {             //加循环
                    if ($("#f" + i).offset().top <= wst + 10) { //判断滚动条位置
                        $('#nav div').css("background-color", "white");
                        $(".f" + i).css("background-color", "red");
                    }
                }
            });
            $('#nav div').click(function () {
                $('html,body').animate({scrollTop: $("#" + this.className).offset().top}, 500);
    //          $("#" + this.className)[0].scrollIntoView(true);//h5 scrollIntoView()
    
            });
        });

    全部代码

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>h5之scrollIntoView控制页面元素滚动</title>
        <style>
    
            /*scrollIntoView*/
            #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;
            }
    
            /*scroll*/
            .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;
    
            }
        </style>
    </head>
    
    <body>
    <div>
        <h2>scrollIntoView</h2>
        <button id="roll1">scrollIntoView(false)</button>
        <button id="roll2">scrollIntoView(true)</button>
    
        <div>
            <div id="myDiv"></div>
            <div id="roll_top">
                scrollIntoView(ture)元素上边框与视窗顶部齐平
                <span id="bottom">scrollIntoView(false)元素下边框与视窗底部齐平</span>
            </div>
        </div>
    </div>
    
    <div>
        <h2>scroll</h2>
        <div id="nav">
            <div class="f1">floor1</div>
            <div class="f2">floor2</div>
            <div class="f3">floor3</div>
            <div class="f4">floor4</div>
            <div class="f5">floor5</div>
        </div>
        <p>
            页面结构
        </p>
        <div class="main">
            <div id="f1">测试1</div>
            <div id="f2">测试2</div>
            <div id="f3">测试3</div>
            <div id="f4">测试4</div>
            <div id="f5">测试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 src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.min.js"></script>
    <script>
        $(function () {
            $(window).scroll(function () {//为页面添加页面滚动监听事件
                var wst = $(window).scrollTop(); //滚动条距离顶端值
                for (var i = 1; i < 6; i++) {             //加循环
                    if ($("#f" + i).offset().top <= wst + 10) { //判断滚动条位置
                        $('#nav div').css("background-color", "white");
                        $(".f" + i).css("background-color", "red");
                    }
                }
            });
            $('#nav div').click(function () {
                $('html,body').animate({scrollTop: $("#" + this.className).offset().top}, 500);
    //          $("#" + this.className)[0].scrollIntoView(true);//h5 scrollIntoView()
    
            });
        });
    </script>
    </body>
    </html>
    View Code
  • 相关阅读:
    23种设计模式-----行为模式
    23种设计模式-----创建型模式、结构型模式
    字节码操作、javassist使用
    反射机制(reflection)
    NFC手机
    NFC简介
    不同技术的过滤条件的定义
    [linux] ubuntu系统tips
    图算法(一)
    跳跃表skiplist
  • 原文地址:https://www.cnblogs.com/puyongsong/p/6805460.html
Copyright © 2011-2022 走看看