使用scroll-behavior属性实现页面平滑滚动的几个问题

在较长的页面中,为了便于用户浏览,开发人员经常会使用锚点链接,锚点链接默认的效果是瞬间跳转,为了让用户体验更好,往往会添加滚动效果。我记得要实现滚动效果,以前一般是结合一段JavaScript代码来实现。

后来偶然知道了scroll-behavior: smooth;这个CSS属性,觉得用来实现滚动效果非常方便。

今天练习了一下这个属性,发现也不是用上就能滚动过的,需要用对,有以下几个问题:

1.scroll-behavior这个属性写在哪个CSS样式中。

我练习的案例中,运行效果如下:

代码如下:

html 复制代码
<div class="box">
			<div class="left">
				<div class="main-box"><a id="lishi">历史沿革</a></div>
				<div class="main-box"><a id="banxue">办学条件</a></div>
				<div class="main-box"><a id="xueshu">学术研究</a></div>
				<div class="main-box"><a id="wenhua">文化传统</a></div>
				<div class="main-box"><a id="xiaoyuan">校园环境</a></div>
			</div>
			<div class="right">
				<a class="anchor" href="#lishi">历史沿革</a>
				<a class="anchor" href="#banxue">办学条件</a>
				<a class="anchor" href="#xueshu">学术研究</a>
				<a class="anchor" href="#wenhua">文化传统</a>
				<a class="anchor" href="#xiaoyuan">校园环境</a>
			</div>
</div>

点击.right右侧的各个条目,.left左侧会跳转到相应的位置。

在本例中,写css代码的时候,scroll-behavior: smooth;这句代码应该定义在.left中,而不应该定义在.main-box中,我理解的是,在哪个区域内滚动,就写在哪里。

2.还要定义父元素的高度

除了写scroll-behavior: smooth;有些属性不写,也不会滚动,在本例中,.left

的父元素.box,高度必须要设置,不一定非要是100%

css 复制代码
			.box {
				height: 100%;      /*高度100%必须要写*/
				display: flex;
				overflow: hidden;
			}

3.需要设置根元素html、body的高度,html和body的高度都要设置,只设置其中一个也不行。

css 复制代码
		html,body {
			position: relative; 
			height: 100%;      	/*高度100%必须要写*/
			overflow: hidden;
	   }

以上是我练习scroll-behavior: smooth;属性时发现的问题,若有不对之处,欢迎批评指正。完整代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">
		<meta name="viewport" content="width=device-width, initial-scale=1.0">
		<title>平滑滚动scroll-behavior</title>
		<style>
			* {
				margin: 0;
				padding: 0;
			}

			ul,
			li {
				list-style: none;
			}

			a {
				text-decoration: none;
			}

			a:hover {
				color: #ff8400
			}

			html,body {
				position: relative;  /*html和body都要定义*/
				height: 100%;      	/*高度100%必须要写*/
				overflow: hidden;
			}

			.box {
				height: 100%;       /*高度100%必须要写*/
				display: flex;
				overflow: hidden;
			}

			.right {
				width: 180px;
			}

			.right .anchor {
				display: block;
				width: 100%;
				line-height: 60px;
				text-align: center;
				font-size: 16px;
			}

			.left {
				width: calc(100% - 180px);
				overflow: auto;
				scroll-behavior: smooth;   /*在哪个范围内滚动,就在哪里加此条语句*/
			}

			.left .main-box {
				width: 100%;
				height: 500px;
				box-sizing: border-box;
				padding: 20px;
				border: 1px solid #23c6d9;
			}
		</style>
	</head>

	<body>
		<div class="box">
			<div class="left">
				<div class="main-box"><a id="lishi">历史沿革</a></div>
				<div class="main-box"><a id="banxue">办学条件</a></div>
				<div class="main-box"><a id="xueshu">学术研究</a></div>
				<div class="main-box"><a id="wenhua">文化传统</a></div>
				<div class="main-box"><a id="xiaoyuan">校园环境</a></div>
			</div>
			<div class="right">
				<a class="anchor" href="#lishi">历史沿革</a>
				<a class="anchor" href="#banxue">办学条件</a>
				<a class="anchor" href="#xueshu">学术研究</a>
				<a class="anchor" href="#wenhua">文化传统</a>
				<a class="anchor" href="#xiaoyuan">校园环境</a>
			</div>
		</div>
	</body>
</html>
相关推荐
LinXunFeng4 分钟前
Flutter - Melos Pub workspaces 实践
前端·flutter·架构
艾小码7 分钟前
前端人必看!3个技巧让你彻底搞懂JS条件判断与循环
前端·javascript
灵感__idea8 小时前
Hello 算法:让前端人真正理解算法
前端·javascript·算法
向葭奔赴♡8 小时前
CSS是什么?—— 网页的“化妆师”
前端·css
黑犬mo8 小时前
在Edge、Chrome浏览器上安装uBlock Origin插件
前端·edge
excel8 小时前
🧩 Vue 3 watch 源码详解(含完整注释)
前端·javascript·vue.js
大前端helloworld8 小时前
前端梳理体系从常问问题去完善-网络篇
前端·面试
excel9 小时前
🌿 一文看懂 Vue 3 的 watch 源码:从原理到流程
前端
繁依Fanyi9 小时前
让工具说话:我在 Inspira Board 里用 AI 把“能用、好用、可复用”落成了日常
前端
weixin_4569042710 小时前
C# 中的回调函数
java·前端·c#