时隔半年……又从新开始写这份指南,算是拿到掘金专栏标识的第一篇正式文章,代码和原文可见👉 GitHub 连接。javascript
做者:©缉熙Soyaine
简介:JavaScript30 是 Wes Bos 推出的一个 30 天挑战。项目免费提供了 30 个视频教程、30 个挑战的起始文档和 30 个挑战解决方案源代码。目的是帮助人们用纯 JavaScript 来写东西,不借助框架和库,也不使用编译器和引用。如今你看到的是这系列指南的第 13 篇。完整指南在 GitHub,喜欢请 Star 哦♪(^∇^*)html建立时间:2017-07-14
最后更新:2017-07-18java
页面中的文章有几张配图,随着页面上下滚动,图片位置划过图片一半时,图片从两侧滑入;图片位置离开可见区域时,图片向两侧滑出。git
下图中蓝色方框位置便是图片所占位置,初始文档中已经写好了内容及样式,须要完成控制图片显示部分的代码来实现图片滑动的效果。github
涉及控制图片的 CSS 属性:框架
translateX
来控制左右移动scale
来控制缩放涉及页面尺寸的属性:ide
window.scrollY
文档从顶部开始滚动过的像素值window.innerHeight viewport
部分的高度ele.height
元素的高度ele.offsetTop
当前元素顶部相对于其 offsetParent 元素的顶部的距离。debounce
的做用:
下降事件监听的频率,使用了 Lodash 中的 debounce 方法。函数
const slideImages = document.querySelectorAll('.slide-in');复制代码
滚动事件监听性能
function checkSlide(e) {
console.log(e);
console.count(e);
}
window.addEventListener('scroll', debounce(checkSlide));复制代码
针对页面的滚动事件进行监听,能够先打出事件对象来看看。同时在接下来的调试过程当中也能利用这打出各个尺寸的值,来帮助咱们感觉每一个尺寸的含义。
此外因为每次滚动都触发监听事件,会下降 JavaScript 运行性能,因此用 debounce
函数来下降触发的次数。ui
.active
类,此处的重点在于判断的条件如何确认,为便于形象地感觉页面滚动时,各个尺寸的变化,我画了一张示意图,以下:// 滑动页面的底部距离扣除图片一半的高
const slideInAt = (window.scrollY + window.innerHeight) - img.height / 2;
// 图片底部距离顶端的距离
const imgBottom = img.offsetTop + img.height;复制代码
须要利用两个临界点来判断图片是否处在须要显示的区域内,故利用两个值来存取此条件的结果(以保证每次事件监听的结果赋值给常亮后,不会随 window
的属性值变化)。// 已滑过了图片的一半
const isHalfShow = slideInAt > img.offsetTop;
// 未彻底滑过图片
const isNotScrollPast = window.scrollY < imgBottom;复制代码
.active
类,不知足的则去掉。if (isHalfShow && isNotScrollPast) {
img.classList.add('active');
} else {
img.classList.remove('active');
}复制代码
至此,图片控制逻辑已所有完成。 亲手滑动感觉一下吧o(*≧▽≦)ツ