【问题标题】:Updating an array on button click Javascript在按钮单击 Javascript 上更新数组
【发布时间】:2014-03-12 20:10:38
【问题描述】:

这个问题可能有点啰嗦,但请耐心等待。

每次用户点击保存按钮时,我都会尝试更新和排列。

当他们点击保存时,页面上的画布图像被创建。

这些 DataURI 值保存在一个数组中。

保存值后,将创建各种缩略图并将其添加到屏幕底部。

单击这些图像上的 X 图标会调用一个函数来从数组中删除正确的图像。

然后应该使用更新数组值重新绘制图像,从而将其从 屏幕。

我已经包含了一些图片来尝试和演示:

图片#1(点击保存并在下方添加图片时):

http://postimg.org/image/cybazwydf/

图像#2(关闭屏幕图像后,添加新图像将删除的图像与新图像一起再次添加):

http://postimg.org/image/gi5pcornl/

这就是问题所在,它重新添加了已删除的值。

我将在下面发布它的代码:

function getDataUrl () {
var a = document.getElementById("theCanvas");
var context = a.getContext("2d");
var dataURL = a.toDataURL();
save(dataURL);
}


var theImages = new Array();




//Add dataURL to array:
function save(URL) {
    theImages.push(URL);
    var x = JSON.stringify(theImages);
    localStorage.setItem('images', x);


drawImages(x);
}

function drawImages(array){

    var array = localStorage.getItem("images");
    array = JSON.parse(array);

    //If an image is saved, display the saveArea div:
    if (array.length > 0){
        document.getElementById("saveArea").style.visibility="visible";
    }

    //Clear the elements that might already be in the div so they don't appear twice:
    var theDiv = document.getElementById("saveArea");
    while (theDiv.firstChild) {
    theDiv.removeChild(theDiv.firstChild);
    }


    for (var x=0; x < array.length; x++){ 
                    //Create image for each value in array:



                    var divimg = document.createElement("div");

                    divimg.style.marginRight="10px";
                    //divimg.style.border = "1px dotted red";
                    divimg.className = "saveContainer";
                    divimg.style.width = 300+"px";
                    divimg.style.padding = 5+"px";
                    divimg.style.marginRight="10px";
                    divimg.style.height = 150+"px";
                    divimg.style.display="inline-block";    
                    divimg.style.marginRight="35px";


                    document.getElementById("saveArea").appendChild(divimg);

                    var img = document.createElement("img");
                    img.src = array[x];
                    img.width = 300;
                    img.height = 150;
                    img.setAttribute("id", "theImageId");
                    img.style.marginRight="10px";
                    img.className = "saveImg";


                    //Add each image to the containing div:
                    divimg.appendChild(img);




                    //Create close button: 
                    var close = document.createElement("img");
                    close.src="close.png";
                    close.width = 50;
                    close.height = 50;
                    close.border = 0;
                    close.style.position="relative";
                    close.style.bottom=115+"px";
                    close.style.right=40+"px";
                    close.className="closeButton";
                    //close.style.cssFloat="right";
                    //close.style.right= 0+"px";


                    var link = document.createElement("a");
                    link.href = "#";

                    link.appendChild(close);

                    link.nameIndex = x;

                    //WHEN THE USER CLICKS THE CLOSE ICON:
                    link.onclick = (function (x) {
                    var imageNum = this.nameIndex;
                    alert("You clicked to close image "+(imageNum+1));
                        //Remove the image:
                        array.splice(x,1);

                        alert("The length of this array is: "+array.length);
                        //Update localStorage:
                        localStorage.removeItem('images');
                        array = JSON.stringify(array);

                        localStorage.setItem('images', array);
                        drawImages(array);
                    } );




                    //Add the close button the the containing div:
                    divimg.appendChild(link);
                    //divimg.appendChild(close);

    } //End Loop

} //End drawImages();

我已经尝试解决这个问题好几个小时了,但没有成功..

【问题讨论】:

    标签: javascript html image canvas


    【解决方案1】:

    从数组中删除图像后,您不会将其存储在任何地方,因此拼接结果会丢失并且数组保持不变

        array.splice(x,1);
    

    需要

        array =  array.splice(x,1);
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-01-17
      • 2020-01-18
      • 1970-01-01
      • 2019-11-24
      • 1970-01-01
      • 1970-01-01
      • 2011-06-16
      • 1970-01-01
      相关资源
      最近更新 更多