您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

h5之scrollIntoView用法详解

2024/2/29 5:24:52发布19次查看
如果滚动页面也是dom没有解决的一个问题。为了解决这个问题,浏览器实现了一下方法,以方便开发人员如何更好的控制页面的滚动。在各种专有方法中,html5选择了scrollintoview()作为标准方法。scrollintoview()可以在所有的html元素上调用,通过滚动浏览器窗口或某个容器元素,调用元素就可以出现在视窗中。如果给该方法传入true作为参数,或者不传入任何参数,那么窗口滚动之后会让调动元素顶部和视窗顶部尽可能齐平。如果传入false作为参数,调用元素会尽可能全部出现在视口中(可能的话,调用元素的底部会与视口的顶部齐平。)不过顶部不一定齐平.
一、scrollintoviewhtml<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?1.1.11"></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 
以上就是h5之scrollintoview用法详解的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product