setBg:function(){ this.bg_1.y=this.bg_1.y-1//每帧下移一个单位 this.bg_2.y= this.bg_2.y-1 if(this.bg_1.y <= -this.bg_1.height){ this.bg_1.y = this.bg_2.y + this.bg_1.height } if(this.bg_2.y <= -this.bg_2.height){ this.bg_2.y = this.bg_1.y + this.bg_1.height } },这段代码是如何让图片交替的,详细解释
时间: 2024-03-30 13:33:13 浏览: 83
这段代码是通过两张背景图片来实现背景滚动的效果,背景图片交替出现。具体解释如下:
首先,这段代码是一个函数 `setBg`,用于设置背景。在这个函数中,有两张背景图片,分别为 `bg_1` 和 `bg_2`。
接下来,每一帧都会让两张背景图片向下移动一个单位,即 `this.bg_1.y=this.bg_1.y-1` 和 `this.bg_2.y = this.bg_2.y-1`。
当 `bg_1` 的位置移动到超出了它的高度时(即 `this.bg_1.y <= -this.bg_1.height`),将 `bg_1` 的位置重置为 `bg_2` 的位置加上 `bg_1` 的高度,这样就可以保证 `bg_1` 在 `bg_2` 的下方,从而实现背景图片的交替出现,即 `this.bg_1.y = this.bg_2.y + this.bg_1.height`。
同样的,当 `bg_2` 的位置移动到超出了它的高度时(即 `this.bg_2.y <= -this.bg_2.height`),将 `bg_2` 的位置重置为 `bg_1` 的位置加上 `bg_1` 的高度,这样就可以保证 `bg_2` 在 `bg_1` 的下方,从而实现背景图片的交替出现,即 `this.bg_2.y = this.bg_1.y + this.bg_1.height`。
这样,每一帧都会让两张背景图片向下移动一个单位,并且在交替出现的过程中,始终保持背景图片的连续性,从而实现了背景滚动的效果。
相关问题
function setBg() { // 设置列表偶数行背景色 #ddd $(".acc-body").find('li:odd').css("background", "#ddd"); }解释代码
这段代码定义了一个名为 `setBg` 的函数,它的作用是设置一个列表的偶数行背景色为灰色(颜色值为 `#ddd`)。
具体来说,`$(".acc-body")` 选择了一个 class 为 `acc-body` 的 DOM 元素,`.find('li:odd')` 在其中查找所有奇数行的 `li` 元素,并使用 `.css("background", "#ddd")` 方法将它们的背景色设置为灰色。
所以,这个函数的目的是为了让列表的奇偶行背景色更加分明,使其更易于阅读。
阅读全文