gpt4 book ai didi

javascript - 如何从函数效果中排除元素

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

在此页面中,当用户单击“显示图像”按钮时,将出现一个随机图像。那挺好的。我需要脚本只影响这张图片。

问题是标题图像也消失了,我需要保持显示所有其他图像。我需要一个解决方案

代码在这里: https://codepen.io/Haitham1000/pen/aXjYzz

function display_random_image() 
{
var theImages = [{
src: "http://farm4.staticflickr.com/3691/11268502654_f28f05966c_m.jpg",
width: "240",
height: "160"
}, {
src: "http://farm1.staticflickr.com/33/45336904_1aef569b30_n.jpg",
width: "320",
height: "195"
}, {
src: "http://farm6.staticflickr.com/5211/5384592886_80a512e2c9.jpg",
width: "500",
height: "343"
}];

var preBuffer = [];
for (var i = 0, j = theImages.length; i < j; i++) {
preBuffer[i] = new Image();
preBuffer[i].src = theImages[i].src;
preBuffer[i].width = theImages[i].width;
preBuffer[i].height = theImages[i].height;
}

// create random image number
function getRandomInt(min,max)
{
// return Math.floor(Math.random() * (max - min + 1)) + min;

imn = Math.floor(Math.random() * (max - min + 1)) + min;
return preBuffer[imn];
}

// 0 is first image, preBuffer.length - 1) is last image

var newImage = getRandomInt(0, preBuffer.length - 1);

// remove the previous images
var images = document.getElementsByTagName('img');
var l = images.length;
for (var p = 0; p < l; p++) {
images[0].parentNode.removeChild(images[0]);
}
// display the image
var targetContainer = document.getElementsByClassName("container");
targetContainer[0].appendChild(newImage);
}

最佳答案

如果 container 是您要删除的图像的唯一位置(例如,之前的图像),您可以只迭代它包含的图像,而不是文档。例如:

// remove the previous images
var targetContainer = document.getElementsByClassName("container")[0];
var images = targetContainer.getElementsByTagName('img');
var l = images.length;
for (var p = 0; p < l; p++) {
images[0].parentNode.removeChild(images[0]);
}
// display the image
targetContainer.appendChild(newImage);

请注意,var targetContainer 已移至顶部,[0] 已添加到其中,images 现在即将到来来自 targetContainer.getElementsByTagName

Codepen

关于javascript - 如何从函数效果中排除元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54680795/

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