粘性定位 sticky 相当于相对定位 relative 和固定定位 fixed 的结合;在页面元素滚动过程中,某个元素距离其父元素的距离达到 sticky 粘性定位的要求时;元素的相对定位 relative...可以看出这个属性的兼容性并不是很好,因为这个 API 还只是实验性的属性。不过这个 API 在 IOS 系统的兼容性还是比较好的。...四、使用 obj.getBoundingClientRect().top 实现 定义: 这个 API 可以告诉你页面中某个元素相对浏览器视窗上下左右的距离。...描述: 当页面往下滚动时,吸顶元素需要等页面滚动停止之后才会出现吸顶效果 当页面往上滚动时,滚动到吸顶元素恢复文档流位置时吸顶元素不恢复原样,而等页面停止滚动之后才会恢复原样 原因:在 ios 系统上不能实时监听...scroll 滚动监听事件,在滚动停止时才触发其相关的事件。
粘性定位 sticky 相当于相对定位 relative 和固定定位 fixed 的结合;在页面元素滚动过程中,某个元素距离其父元素的距离达到 sticky 粘性定位的要求时;元素的相对定位 relative...二、使用 JQuery 的 offset().top 实现 我们知道 JQuery 中封装了操作 DOM 和读取 DOM 计算属性的 API,基于 offset().top 这个 API 和 scrollTop...描述: 当页面往下滚动时,吸顶元素需要等页面滚动停止之后才会出现吸顶效果 当页面往上滚动时,滚动到吸顶元素恢复文档流位置时吸顶元素不恢复原样,而等页面停止滚动之后才会恢复原样 原因:在 ios 系统上不能实时监听...scroll 滚动监听事件,在滚动停止时才触发其相关的事件。...既然有读取元素的属性就自然会导致页面 reflow。 因此我们优化的方向就是从减少读取元素属性次数下手,查看代码发现一触发屏幕滚动事件就会调用相关方法读取元素的偏移量。
一.场景 “吸顶”是一种比较老的交互方式,在PC页面已经用了很多年了,如图: sticky 吸顶元素的初始位置一般靠近页面顶部,但与顶部有一定距离,这块区域放的是最醒目的元素,比如Banner图...(最重要的元素通常固定在页面顶部,navbar-fixed-top) 二.PC解决方案 页面滚动到一定位置时,做一些事情 “回到顶部”按钮也是这样的,页面向下滚动超过150px时,显示该按钮,否则隐藏...(引自参考资料1) 只要页面还在滚动,scroll事件就疯狂触发,需要手动节流,这正是我们需要的效果。...,iscroll等等 有前辈做了详细测试,见参考资料1 定时器在手指没有离开屏幕时不会执行,touchmove触发频率足够,也能拿到scrollTop,但touchend后,惯性滚动期间,没有任何事件可用...IOS 8+的Safari和WKWebView能够疯狂触发scroll,无论手指在不在屏幕上,无论是不是惯性滚动期间。
,这样就可以避免页面的跳动,但是直接给 html 设置 absolute 风险太大,容易埋坑,不太建议大项目使用,小应用还是可以的,我在需求的小活动页7就使用过这种方式 5禁用页面滚动 除了在 css...所以只好等回调执行完毕,大概 200ms 后, 页面再开始响应滚动,所以会显得不那么跟手 现在通过 参数 passive 就可以事先告诉浏览器 这个监听回调不会 执行 preventDefault,你可以马上响应滚动不用等待...,本来整个页面都不能滚了 但是子元素 调用了 stopPropagation() 之后,不仅元素可以滚了,还会导致滚动穿透(毕竟只要元素能滚就能发生穿透) 但是document 还是不会滚动的 3滚动穿透的触发条件...一次没有抬起的滚动行为(手没有离开屏幕)导致元素滚动到顶部或者 底部之后,如果手还在屏幕上往两端滑,并不会触发滚动穿透 如果你把元素滚动到 两端不可滚之后,抬起手,再按下去,往不可滚的方向移动,此时才会发生...滚动穿透 之前我们说了,滚动响应有两种对象,element 和 document 从这里可以意识到,单次的滚动行为 只会绑定一个滚动对象,不会切换响应对象 只是在开始滚动的时候,浏览器会根据情况,选择响应滚动的对象
0);”> 解决方案2: 在于你的布局,可以用定位position:fixed;来做处理,因为他相对于页面来说,定位于屏幕一定的位置。 ...element.scrollIntoView(); 监听input元素的focus事件,以及window的resize事件。因为focus事件将在resize事件前触发。 ...在resize事件中,获得浏览器可视区域的top和bottom。...获得浏览器可视区域的位置: var viewTop = $(window).scrollTop(), // 可视区域顶部 // 可视区域底部 // 不使用jQuery var viewTop = document.body.scrollTop...// 调整视窗位置 $(window).scrollTop(value); // 调整value // 不使用jQuery window.scrollTo(0, value); // 调整value
该系列会写一些 PbootCMS 在使用过程中碰到的一些问题,以及问题的解决方案。 大家也可以给我反馈一些问题,有空的时候我会选一些写出来放在这个系列的教程里面。...由于 PbootCMS 的 api 接口的存在,在 PbootCMS 上实现 Ajax 加载还是比较方便的。 一、点击更多按钮加载内容 1、首先,添加一个按钮用来触发事件。...var Dom = jQuery('.list'); //接下来写在点击按钮('.more')的时候触发事件 jQuery('#More').on('click', function(){ ...二、页面滑动到底部加载更多文章 原理同上,只不过改变一下事件,原来是点击按钮触发的,改成滚动监听。...; //判断:(窗口与页面顶部距离 + 窗口高度) >= 页面的高度(也就是滚动到页面底部的时候),并且开关是开启状态,执行ajax加载内容 if( ( WindowTop +
(该方法也可以获取 H5 自定义属性) 1.1.3 数据缓存 data() data() 方法可以在指定的元素上存取数据,并不会修改 DOM 元素结构。一旦页面刷新,之前存放的数据都将被移除。...注意:此方法用于遍历 jQuery 对象中的每一项,回调函数中元素为 DOM 对象,想要使用 jQuery 方法需要转换。...案例: 品优购电梯导航(上) 1.当我们滚动到 今日推荐 模块,就让电梯导航显示出来 2.点击电梯导航页面可以滚动到相应内容区域 3.核心算法:因为电梯导航模块和内容区模块一一对应的 4.当我们点击电梯导航某个小模块...案例:品优购电梯导航(下) 1.当我们点击电梯导航某个小li, 当前小li 添加current类,兄弟移除类名 2.当我们页面滚动到内容区域某个模块, 左侧电梯导航,相对应的小li模块,也会添加current...3.触发的事件是页面滚动,因此这个功能要写到页面滚动事件里面。 4.需要用到each,遍历内容区域大模块。
1、返回顶部按钮 通过使用jQuery中的animate 和scrollTop 方法,不用插件就可以创建一个滚动到顶部的简单动画: // Back to top $('.top').click(function...所有你真正需要做的是在800毫秒的时间内设置文档主体的动画,直到它滚动到文档的顶部。 注:小心scrollTop的一些错误行为。...,也不想要重新加载页面——你可能希望链接做点别的事情,例如说触发一些其他脚本。...Visibility时触发 当用户不再关注某个tab,或重新聚焦原来的那个tab上时,触发JavaScript: $(document).on('visibilitychange', function...允许“链式”插件的方法调用,以减轻反复查询DOM并创建多个jQuery对象的过程。
1.什么是图片懒加载 图片懒加载就是鼠标滑动到哪里,图片加载到哪里。...px开始加载图片 failure_limit : 3, //img加载失败到第4张开始停止加载图片 event : “scroll”, //触发事件 effect : “show”,...触发appear事件时执行的回调 load : null, //在img触发load事件时执行的回调 placeholder:"data:image/png;base64,,,,," //...var imgs = document.querySelectorAll("img"); //获取所有的img元素 window.onscroll = function(){ //定义触发事件...|| document.documentElement.scrollTop; for(var i =0 ; i<imgs.length;i ++){ //判断图片到页面的高度与可视高度和滑动高度的大小
,目前的解决方案是将自动上推改成手动上推,让我们自己来控制页面内容的滚动。...最终实现效果如下:图片二、方案二有些手机或者版本过低,监听不到键盘事件,可以使用聚焦事件和失焦事件代替,事件对象中也返回了键盘的高度。...,有可能会滚动错误解决:获取到元素坐标后,最好只保留两位小数,计算时注意处理精度3、问题:当页面同时有input和textarea时,若只给textarea绑定键盘事件,input会触发该textarea...的键盘事件解决1:使用方案二解决2:某些特殊情况,可以将textarea隐藏,不要在键盘弹起时让input和textarea同时存在页面中,那么input的键盘事件触发后,可能依然会触发textarea...textarea触发键盘事件,再点击input触发键盘事件,input获取到的键盘高度是有完成那栏的,导致页面上推距离不准解决:不要使用原生的完成,自定义一个完成,键盘弹起时将他使用动画移动到键盘之上,
jQuery 里和滚动条有关的概念很多,但是有三个属性和滚动条的拖动有关,就是:scrollTop、scrollLeft、scrollHeight。...滚动条向下拖动一段距离,看到的页面效果如下(右部的a、b是我抓图后,用PS标出来的): 那么,这里的外部div 的scrollTop、scrollHeight 属性到底是什么呢?...实际上,在js代码里,滚动条是被抽象为一个“点”来对待的。scrollHeight其实不是“滚动条的高度”(b),而是表示滚动条需要滚动的高度,即内部div的高度750px。...而scrollTop表示滚动条(一个点)当前的位置在750px里占了多少,不是图中标出的a。...程序中,在外部div的scroll(滚动)事件中侦测和执行if判断语句,是非常消耗CPU资源的。用鼠标拖拉滚动条,只要有一个像素的变动就会触发该事件。但点击滚动条两头的箭头,事件触发的频率会低得多。
.zip && unzip 01.zip && rm 01.zip 在浏览器中预览 index.html 页面 目标效果 请在 js/index.js 文件中补全代码,最终实现传送门的功能。...具体需求如下: 点击页面侧边的顶部、中间或底部按钮,页面滚动到顶部、中间或底部对应的范围内。这三个范围的设定如下: 顶部:滚动条距离页面顶部 0 ~ 960px(不包含 960)的范围。...document.documentElement.scrollTop = scrollTopVal;:将页面滚动到指定的高度。 四、工作流程▶️ 1....点击链接: 用户点击侧边栏上的链接,触发 onclick 事件,调用 toFunction 函数。 toFunction 函数将页面滚动到指定的高度。 3....页面滚动: 当用户滚动页面时,触发 $(window).scroll 事件。 获取当前页面的滚动高度,根据滚动高度所在的范围确定对应的索引。
jQuery 里和滚动条有关的概念很多,但是有三个属性和滚动条的拖动有关,就是:scrollTop、scrollLeft、scrollHeight。...滚动条向下拖动一段距离,看到的页面效果如下(右部的a、b是我抓图后,用PS标出来的): 那么,这里的外部div 的scrollTop、scrollHeight 属性到底是什么呢?...实际上,在js代码里,滚动条是被抽象为一个“点”来对待的。scrollHeight其实不是“滚动条的高度”(b),而是表示滚动条需要滚动的高度,即内部div的高度750px。...而scrollTop表示滚动条(一个点)当前的位置在750px里占了多少,不是图中标出的a。 这时,我们很叹服Windows的设计者,滚动条设计的如此形象美妙,欺骗了多少头脑简单的鼠标操作员。...程序中,在外部div的scroll(滚动)事件中侦测和执行if判断语句,是非常消耗CPU资源的。用鼠标拖拉滚动条,只要有一个像素的变动就会触发该事件。但点击滚动条两头的箭头,事件触发的频率会低得多。
获取水平和垂直滚动条滚动滚动距离 当满足scrollHeight - scrollTop == clientHeight时,表明垂直滚动条滚动到底了 阅读知情同意书的小案例 onmousemove事件和事件对象...----火狐不支持,由DOMMouseScroll替代 判断滚轮上滚还是下滚----火狐不支持,由detail替代 取消滚动条随滚轮移动的默认行为 键盘事件 浏览器对象模型---navigator...JSON字符串 eval函数 ---- window.onload:事件 浏览器加载一个页面时,是按照自上而下的顺序加载的,读取到一行就运行一行,如果将script标签写到页面上边,在代码执行的时候,页面还没有完全加载...window.onload事件会在整个页面加载完成之后,才会触发,将对应的script代码,写在里面,可以确保script代码可以在页面加载完成之后,才会执行 <!...; var ly=event.clientY-obj.offsetTop; //当触发鼠标按下事件之后,obj会跟随鼠标移动 //即触发鼠标在当前页面的移动事件
当页面包含多个滚动区域时,滚完一个区域后若还存在滚动动量则会将这些剩余动量传播到下一个滚动区域,造成该区域也滚动起来。这种行为称为滚动传播。 若不想产生这种奇怪行为可直接禁止。...select option { direction: rtl; } 复制代码 修复点击无效 在苹果系统上有些情况下非可点击元素监听click事件可能会无效,针对该情况只需对不触发click事件的元素声明...当然还有另一种解决方案。pageshow事件在每次页面加载时都会触发,无论是首次加载还是再次加载都会触发,这就是它与load事件的区别。...当输入完成键盘占位消失后,页面高度有可能回不到原来高度,产生坍塌导致Webview底色露脸,简单概括就是输入框失焦后页面未回弹。...为了能让媒体在页面加载完成后自动播放,只能显式声明播放。
第一个考虑的上拉加载事件:onReachBottom页面滚动到底部的事件,常用于上拉加载下一页数据。...第一个问题就是当滚动条滚动到底部时会多次触发scrolltolower事件,第二个问题是当页面由第一个scroll-view(该页面已经到了的最底部了)切换到第二个scroll-view时会自动滚动到页面的最底部...三、解决方案: 关于页面到最底部多次触发scrolltolower事件解决: 在scrolltolower触发事件中设定一个定时器setTimeout(callback, delay, rest...切换到第二个scroll-view时会自动滚动到页面的最底部: 设置一个scrollTop设置竖向滚动条的位置,首先默认为0,当页面向下滚动会触发scroll-top事件从而改变scrollTop的值...,当切换到第二个scroll-view时在默认设置scrollTop为0,那么在切换到第二个页面的同时页面的竖向滚动条的位置会默认滚动到最顶部,从而解决了默认滚动到最底部加载多次数据的问题。
当页面包含多个滚动区域时,滚完一个区域后若还存在滚动动量则会将这些剩余动量传播到下一个滚动区域,造成该区域也滚动起来。这种行为称为「滚动传播」。 若不想产生这种奇怪行为可直接禁止。...select option { direction: rtl; } 修复点击无效 在苹果系统上有些情况下非可点击元素监听click事件可能会无效,针对该情况只需对不触发click事件的元素声明...当然还有另一种解决方案。pageshow事件在每次页面加载时都会触发,无论是首次加载还是再次加载都会触发,这就是它与load事件的区别。...当输入完成键盘占位消失后,页面高度有可能回不到原来高度,产生坍塌导致Webview底色露脸,简单概括就是输入框失焦后页面未回弹。...为了能让媒体在页面加载完成后自动播放,只能显式声明播放。
判断滚动条到底部,需要用到DOM的三个属性值,使用jQuery分别是: $('body').scrollTop()为滚动条在Y轴上的滚动距离。...10 3.进入判断首先解除(防止进行多次ajax请求) $(window).unbind('scroll',isScrollBottom); 4.返回数据,渲染到页面并再次绑定监听事件 $(window...、clientHeight、scrollHeight scrollTop为滚动条在Y轴上的滚动距离。...window.addEventListener('scroll',isScrollB0ttom ,false); } }; 注意: 1.每次满足滑动到底部进入判断先解除监听事件; 2.每次加载数据渲染完后...,必须再次绑定监听事件; 3.判断触发条件使用一个小的范围。
对于移动端页面,我们一般会用每次滚动到接近页面底部时,加载更多(下一页)数据的方式。本文就来介绍下滑动到底部无限加载的实现。...实现滑动到底部无限加载,我们要做的是: 监听显示数据内容的元素的滚动事件。 每次元素滚动时,若此时不在加载数据,则计算元素下方没显示的高度值。...如果其值小于我们设定的触发加载的值,则加载,显示更多数据;否则什么都不做。 如果没有更多的内容可显示,则不再监视元素的滚动事件。...参考 html中offsetTop、clientTop、scrollTop、offsetTop各属性介绍 关于页面滚动值scrollTop在FireFox与Chrome浏览器间的兼容问题 推荐阅读 6...jQuery Infinite Scrolling Demos 无限加载 grid 的列表,文章,图片带分页等。
navigator.userAgent.match(/msie/i) ){ alert('I am an old fashioned Internet Explorer'); } }); 2、平稳滑动到页面顶部...这是一个最广泛使用的jQuery效果:对一个链接点击下会平稳地将页面移动到顶部。...= $win.scrollTop() if (scrollTop >= navTop && !...$('img').error(function(){ $(this).attr('src', 'img/broken.png'); }); 注:jQuery1.8后已经禁用error事件 7、检测复制...问题在于target=”blank”属性并不是W3C有效的属性。让我们用jQuery来补救:下面这段代码将会检测是否链接是外链,如果是,会自动添加一个target=”blank”属性。