我使用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();
}
答案 0 :(得分:1)
考虑到你是在追求一些想法,这就是我的想法。我猜是因为我们没有HTML
,我们也看不到你在哪里调用哪个函数。
但名称windowSize()
表明我可能会在窗口调整大小时调用它,特别是您正在使用窗口的当前大小。
这让我更加确定你必须在resize()
中调用它。因此,它有时可以被调用两次(实际上这个数字没有保证,这当然取决于所使用的浏览器)---这可能是它。
要解决您的问题,只需在决定添加之前检查它是否存在。
同样在你的windowSize()
方法中,下面的测试不必在for循环中 - 将它移到for循环之外(在删除if语句的路上)将它放在它之后。
if (i == cantProyectos) {
cargarProyectos(cantProyectos, posicionDetalle);
}