当前位置: 代码迷 >> JavaScript >> 如何从功能效果中排除元素
  详细解决方案

如何从功能效果中排除元素

热度:69   发布时间:2023-06-13 11:47:49.0

在此页面中,当用户单击“显示图像”按钮时,将显示随机图像。 那很好。 我需要脚本仅影响此图像。

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

代码在这里: :

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);
}

您正在查找,然后循环浏览页面上的每个图像以将其删除。 代替var images = document.getElementsByTagName('img'); 尝试将图像放入容器中 ,然后更换它们。

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

    //GET THE CONTAINER FIRST
    var targetContainer = document.getElementsByClassName("container")[0];
    //FIND THE IMAGES IN CONTAINER ONLY
    var images = targetContainer.getElementsByTagName('img');
    var l = images.length;
    for (var p = 0; p < l; p++) {
        images[0].remove();
    }
    // display the image
    targetContainer.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

  相关解决方案