gpt4 book ai didi

javascript - 使用数组中的图像填充多个 div,且不重复

转载 作者:行者123 更新时间:2023-11-28 08:46:20 25 4
gpt4 key购买 nike

我有一个包含 15 个 div 元素的页面。我需要用至少 36 张图像的数组中的随机图像填充每个 div。然后我需要让图像以随机间隔旋转。我让这部分使用 Choose image URL from large array, insert into random DIV on page, cycle 中提供的解决方案。 .

我想改进代码,以便如果图像已经显示在页面上,则不允许从数组中调用图像。这就是我所坚持的。

这是我到目前为止的代码。

function random_int(max) {
return Math.floor(Math.random() * max);
}

$(document).ready(function() {
var images = ['http://placekitten.com/159/159', 'http://placekitten.com/160/160', 'http://placekitten.com/161/161', 'http://placekitten.com/162/162', 'http://placekitten.com/163/163', 'http://placekitten.com/164/164', 'http://placekitten.com/165/165', 'http://placekitten.com/166/166', 'http://placekitten.com/167/167', 'http://placekitten.com/168/168', 'http://placekitten.com/169/169', 'http://placekitten.com/170/170', 'http://placekitten.com/171/171', 'http://placekitten.com/172/172', 'http://placekitten.com/173/173', 'http://placekitten.com/174/174', 'http://placekitten.com/175/175', 'http://placekitten.com/176/176', 'http://placekitten.com/177/177', 'http://placekitten.com/178/178', 'http://placekitten.com/179/179'];
var $divs = $('div.projectItem');

$divs.each(function() {
$('<img width="100%" />', {
src: 'http://placekitten.com/180/180',
alt: this.id
}).appendTo(this);
});

function switchImage() {
var $div = $divs.eq(random_int($divs.length));
var image = images[random_int(images.length)];

$div.find('img').attr('src', image);
}

var imageChanger = setInterval(switchImage, 500);
});

I have created a JSfiddle example .

我想要实现的另一件事是在页面首次加载时在每个 div 中都有一个图像。您会注意到,在 jsfiddle 示例中,div 是空的,并且在页面加载后可以保持这种状态一段时间。我尝试在每个 div 中包含一个初始 img 标签,但是当加载随机图像时,它们不会替换初始图像,并且每个 div 最终都会包含两个图像。我相信这是因为 .appendTo(this);。我想我必须将其更改为 replaceChild 或类似的?

首次发帖者和 JS 初学者感谢任何帮助。

最佳答案

每次添加图像时只需从数组中删除图像即可。
替换图像后,不要忘记将图像从 IMG 标记推送到数组中。

类似这样的事情:

function random_int(max) {
return Math.floor(Math.random() * max);
}

$(document).ready(function() {
var images = ['http://placekitten.com/159/159', 'http://placekitten.com/160/160', 'http://placekitten.com/161/161', 'http://placekitten.com/162/162', 'http://placekitten.com/163/163', 'http://placekitten.com/164/164', 'http://placekitten.com/165/165', 'http://placekitten.com/166/166', 'http://placekitten.com/167/167', 'http://placekitten.com/168/168', 'http://placekitten.com/169/169', 'http://placekitten.com/170/170', 'http://placekitten.com/171/171', 'http://placekitten.com/172/172', 'http://placekitten.com/173/173', 'http://placekitten.com/174/174', 'http://placekitten.com/175/175', 'http://placekitten.com/176/176', 'http://placekitten.com/177/177', 'http://placekitten.com/178/178', 'http://placekitten.com/179/179'];
var $divs = $('div.projectItem');

$divs.each(function() {
$('<img width="100%" />', {
src: 'http://placekitten.com/180/180',
alt: this.id
}).appendTo(this);
});

function switchImage() {
var $div = $divs.eq(random_int($divs.length));
var image_i = random_int(images.length);
var image = images[image_i];
var $img = $div.find('img');

images.splice(images_i,1);
images.push($img.attr("src"));

$img.attr('src', image);
}

var imageChanger = setInterval(switchImage, 500);
});

祝你好运。

关于javascript - 使用数组中的图像填充多个 div,且不重复,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19752549/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com