大家好,又见面了,我是你们的朋友全栈君。
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>
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/142018.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...