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>

时间: 2024-10-20 13:08:35

h5之scrollIntoView控制页面元素滚动的相关文章

控制页面元素的显示和隐藏

CreateTime--2017年7月13日07:30:55Author:Marydon js控制页面元素的显示和隐藏&<c:if></c:if>标签控制页面元素的显示和隐藏 说明:本文的重点在使用后者实现 实例: 医嘱类型分为:长嘱,临嘱,中医三种,页面默认只显示长嘱信息,点击临嘱或中医显示对应信息:选中变色. CSS部分: /* 医嘱:长嘱,临嘱,中医样式显示 Start*/ .yz_td1 { line-height: 28px; height: 28px; padd

JS/jquery实现鼠标控制页面元素显隐

最近因为公司网站要上一个活动广告横幅,当用户鼠标划过时显隐二维码.像这种鼠标事件控制页面元素显隐的情况,码农们会经常遇到,可以通过javascript或jquery代码实现,下面就几种常见需求一起归纳一下. mouseout和mouseleave 这里需要特别注意mouseout与mouseleave的区别.我们通过下面代码示例来看一下: <p style="color:#333333;font-family:-apple-system, " font-size:16px;&qu

使用JS控制页面元素位置移动

主要使用一下两个函数 parseInt() substr() 首先获取元素的ID var j = document.getElementById("ID"); 然后获取位置属性 var top = j.style.top //这里以控制元素上下位置距离,控制左右的话把top换成left即可 需要注意的是,使用此方法需要把要移动的元素设置为绝对定位,样式中添加    position:absolute; 现在开始移动元素位置了,因为使用方法获取的元素应该为(“0px”)为string字符

AngularJS中的route可以控制页面元素的改变,使多页面变成一个单页面。。。

第一步:引入必要的js: 1 <script src="js/lib/angular.js"></script> 2 <script src="js/lib/angular-animate.min.js"></script> 3 <script src="js/lib/angular-route.min.js"></script><br><br><

鼠标滚轮控制页面横向滚动

metrojs.js和jquery.mousewheel.min.js这两个是必须要有的 <!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> <script src="js/jquery-1.4.2.min.js" type="text/javascript"><

selenium 常见操作,js操作-将元素滚动到页面可见区域

我们在自动化测试中,会遇到需要把浏览器页面的元素移动到可见区域,就需要使用页面向上或者向下滚动 js操作-滚动条:使用: selenium 当中使用 execute_script   (译:埃克斯Q特.思怪泼特) 方法 执行 js 语句: 页面元素滚动到可见区域常用的操作: 1.移动到元素element对象的“底端”与当前窗口的“底部”对齐: driver.execute_script("arguments[0].scrollIntoView(false);",element) 2.移

activePDF Architect WBE 控件可动态产生自定义PDF文件,控制布局和页面元素

activePDF Architect WBE 控件提供了强健的API用于即时地构建完美的PDF报表.PDF表单等,可以添加文本.图像.表格.注释.表单字段等,并且可以完全控制格式和布局位置,直接从你应用程序产生高质量的PDF文档. 具体功能: 动态产生自定义PDF文件,控制布局和页面元素 从头开始构建PDF,使用强健的表格控件和其他工具创建专业的适合你商业标准的布局 整合交互式元素到PDF里,如超链接.表单字段.注释等 直接从应用程序或者数据库数据,快速且简便地创建大批量PDF文件 使用相似的

[转载]用Javascript获取页面元素的位置

原文地址:http://www.ruanyifeng.com/blog/2009/09/find_element_s_position_using_javascript.html 制作网页的过程中,你有时候需要知道某个元素在网页上的确切位置. 下面的教程总结了Javascript在网页定位方面的相关知识. 一.网页的大小和浏览器窗口的大小 首先,要明确两个基本概念. 一张网页的全部面积,就是它的大小.通常情况下,网页的大小由内容和CSS样式表决定. 浏览器窗口的大小,则是指在浏览器窗口中看到的那

selenium 总结篇,常见方法和页面元素的操作

今天,总结一下selenium怎么操作web页面常见的元素. 主要有: 上传 alter dialog prompt dialog confirm dialog select list radio box input box checkBox 测试页面如下: 1 <html> 2 <head> 3 <title>selenium处理基本页面元素</title> 4 <style type="text/css"> 5 table