js循环精灵图

js循环精灵图

循环精灵图可以不用在给每一个小块一 一的修改位置。
主要原理是找到整张的背景图与li的下标的数学关系
左侧是一大张背景图 右侧是成品是预览图

在这里插入图片描述在这里插入图片描述

这个背景图的位置其实是有规律的,每两张之间间隔一个固定长度 为20px,小图标的长度为24px,我们就可以得出这个间隔44px。然后使用这个间隔移动这个大背景图的位置达到精灵图的效果。我们的每一个span中都会有一个 background-image 因此我们只需要关注 大背景图的纵坐标上的移动。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style type="text/css">
			ul {
				width: 216px;
			}
			li {
				width: 70px;
				height: 70px;
				list-style: none;
				float: left;
				border: 1px solid black;
				text-align: center;
			}
			span {
				background: url(./jingling.png) 0 0 no-repeat;
				display: inline-block;
				width: 24px;
				height: 24px;
				margin-top: 11px;
			}
		</style>
		<script type="text/javascript">
			window.onload = function() {
				var spans = document.getElementsByTagName('span')
				//核心代码
				for (var i = 0; i < spans.length; i++) {
					var index = i * 44;
					spans[i].style.backgroundPosition = "0 -" + index + "px";
					//这个值 是负的原因是我们的大背景图是向上移动的
				}
			}
		</script>
	</head>
	<body>
		<ul>
			<li> <span></span> </li>
			<li> <span></span> </li>
			<li> <span></span> </li>
			<li> <span></span> </li>
			<li> <span></span> </li>
			<li> <span></span> </li>
			<li> <span></span> </li>
			<li> <span></span> </li>
			<li> <span></span> </li>
		</ul>
	</body>
</html>


版权声明:本文为qq_44983621原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。