Skip to content

Commit c6e190b

Browse files
committed
add readme for challenge 24
1 parent 9e022cd commit c6e190b

File tree

1 file changed

+56
-0
lines changed

1 file changed

+56
-0
lines changed

24 - Sticky Nav/README.md

Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
2+
> 在Github上看到了[wesbos](https://twitter.com/wesbos)的一个Javascript30天挑战的[repo](https://github.com/wesbos/JavaScript30),旨在使用纯Js来进行练习,不允许使用任何其他的库和框架,该挑战共30天,我会在这里记录下自己练习的过程和遇到的问题。
3+
4+
![demo](images/0724-demo.gif)
5+
6+
第24天的训练是做一个下滑到导航栏,使之固定的样式。这个样式在日常生活中是很常见的效果,为了当用户在内容不断下滑后能够较快速的跳转到自己所需的其他内容,网站一般会加上这个效果,方便用户更快的进行页面导航。
7+
> [线上DEMO](http://htmlpreview.github.io/?https://github.com/winar-jin/JavaScript30-Challenge/blob/master/24%20-%20Sticky%20Nav/index.html)
8+
9+
## 源代码
10+
```Javascript
11+
let nav = document.querySelector('nav#main');
12+
// 导航栏距离document顶部的距离
13+
let navTop = nav.offsetTop;
14+
function fixNav(){
15+
// window.scrollY 是当前窗口的滚动距离
16+
if(window.scrollY >= navTop){
17+
document.body.style.paddingTop = `${nav.offsetHeight}px`;
18+
document.body.classList.add('fixed-nav');
19+
} else {
20+
document.body.style.paddingTop = 0;
21+
document.body.classList.remove('fixed-nav');
22+
}
23+
}
24+
document.addEventListener('scroll',fixNav);
25+
```
26+
总体来说,思路比较简单:
27+
* 获取导航栏到document顶部的距离;
28+
* 监听页面的滚动事件;
29+
* 当页面滚动距离大于或等于导航栏顶部距离时,为`body`添加新的类名`fixed-nav`
30+
* 因为在`.fixed-nav`下的`nav`是固定`fixed`布局,因此会脱离文档流,底下的内容会自动向上去,因此此时在滚动到导航栏是页面会有上下的跳动。解决方法如下:在滚动到`nav`时,为页面`body`添加`padding-top`的值为导航栏的高度(`nav.offsetHeight`)。
31+
32+
## CSS
33+
34+
* 添加上`.fixed-nav`的类的相关样式:
35+
```CSS
36+
.fixed-nav .site-wrap{
37+
transform: scale(1);
38+
}
39+
.fixed-nav nav{
40+
position: fixed;
41+
box-shadow: 0 10px 10px rgba(0,0,0,0.2);
42+
}
43+
.fixed-nav li.logo{
44+
max-width: 500px;
45+
}
46+
```
47+
在样式里面,有一个比较核心的和动画相关的属性:`transition:all 0.2s;`。该条属性能够控制页面的样式从一个状态到另一个状态的过渡时间,其间的过渡动画会自动创建。
48+
49+
* `.fixed-nav .site-wrap`:页面的主体内容在下滑到导航栏时会有一个细微的放大效果,从0.98-1。
50+
* `.fixed-nav nav`:当滑动到导航栏位置时,设置导航栏相对窗口固定布局,且有一个阴影,营造出3D的效果。
51+
* `.fixed-nav li.logo`:当滑动到导航栏的位置时,设置导航列表最左侧的logo图标显示出来。这里这所以要设置`max-width`属性,是因为列表采用了flex布局,且`flex:1;`,代表让所有弹性盒模型对象的子元素都有相同的长度,并且忽略它们内部的内容,因此这里所有的`li`元素都会有相同的宽度。假设我们设置它的`width`属性,不管宽度为多少,都不会有作用,都会显示相同的宽度。因此,设置`max-width`对其进行宽度上的限制。
52+
53+
END! 💯
54+
55+
56+

0 commit comments

Comments
 (0)