0

我使用 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();
}
4

1 回答 1

1

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

但是这个名字windowSize()暗示我你可能会在调整窗口大小时调用它,特别是你正在使用窗口的当前大小。

这使我更加确定您必须调用它resize()。因此,它有时会被调用两次(实际上这个数字并不能保证,它肯定取决于所使用的浏览器)——可能就是这样。

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

同样在您的windowSize()方法中,以下测试不必要地位于 for 循环内部 - 将其移到 for 循环之外(在删除 if 语句的途中)将其放在它之后。

    if (i == cantProyectos) {
        cargarProyectos(cantProyectos, posicionDetalle);
    }
于 2012-06-15T23:06:29.907 回答