添加附加出现两次

时间:2012-06-15 22:42:22

标签: jquery html append

我使用append添加另一个div

 $('#'+ number).append('<div id="descc'+number+'" class="backgroundImage" style="font-size:10px; height:13px; color:#fff; background-color:#000;" align="center">'+ descA+'</div>'); 

div出现两次而remove()不起作用,有什么想法吗?

function getDesc(number) {
    $.getJSON('getDescription.php?number=' + number, function(des) {
        descA = des;
        $('#' + number).append('<div id="descc' + number + '" class="backgroundImage" style="font-size:10px; height:13px; color:#fff; background-color:#000;" align="center">' + descA + '</div>');
    });
}

function cargarProyectos(cant, col) {
    for (i = 1; i <= cant; i++) {
        $('#proyectos').append('<div class="backgroundImage" id="' + i + '" style="position:relative; float:left; width:186px; height:150px; background-image: url(../CMS/_class/image.php?id=' + i + ' ); margin-top: 10px;margin-right:10px; margin-bottom:10px; cursor:hand;"></div>');
        $('#' + i).html('<div class="backgroundImage" style="font-size:10px; height:13px; color:#fff; background-color:#000;" align="center">PROYECTO ' + i + '</div>');
        getDesc(i);
        if (!(i % col) && i != 1) {
            $('#proyectos').append('<div class="scroll"  id="detalle' + Math.floor((i / col)) + '" style="position:relative; white-space: nowrap;display:none;  width:100%; height:0px; background-color:#e8e8e8; margin-bottom:10px;">            </div>');
        } else if (i == cant) {
            $('#proyectos').append('<div class="scroll" id="detalle' + Math.floor((i / col) + 1) + '" style="position:relative; display:none;white-space: nowrap; width:100%; height:0px; background-color:#e8e8e8; margin-bottom:10px;"></div>');
        }
    }
}

function windowSize() {
    winW = $('#proyectos').width();
    posicionDetalle = Math.floor(winW / 160);
    for (i = 1; i <= cantProyectos; i++) {
        $('#descc' + i).remove();
        $('#' + i).remove();
        if (i == cantProyectos) {
            cargarProyectos(cantProyectos, posicionDetalle);
        }
    }
    attachClickEvent();
}

1 个答案:

答案 0 :(得分:1)

考虑到你是在追求一些想法,这就是我的想法。我猜是因为我们没有HTML,我们也看不到你在哪里调用哪个函数。

但名称windowSize()表明我可能会在窗口调整大小时调用它,特别是您正在使用窗口的当前大小。

这让我更加确定你必须在resize()中调用它。因此,它有时可以被调用两次(实际上这个数字没有保证,这当然取决于所使用的浏览器)---这可能是它。

要解决您的问题,只需在决定添加之前检查它是否存在。

同样在你的windowSize()方法中,下面的测试不必在for循环中 - 将它移到for循环之外(在删除if语句的路上)将它放在它之后。

    if (i == cantProyectos) {
        cargarProyectos(cantProyectos, posicionDetalle);
    }