我正在尝试使用 OpenLayers 2.11 创建空间调查,但在关闭多个弹出窗口的功能方面存在一些问题。

以下代码适用于一个弹出窗口,但该函数无法关闭多个弹出窗口并发布内容。

创建新弹出窗口时,是否有 OpenLayers 方法来销毁旧弹出窗口?

function submitform() {
  document.myform.submit();
  loop_popups();
}

——
function loop_popups() {
  for( var i = 0; i < map.popups.length; ++i ) {
    map.removePopup(map.popups[i]);
  };
}

——
<form name="myform" action="sqlinsert.php" method="post" target="_blank">
<a href="javascript: submitform()">Save/close</a>

最佳答案

使用 i 对数组进行计数,同时从中删除成员只会删除一半的标记。相反,请尝试:

while( map.popups.length ) {
  map.removePopup( map.popups[0] );
}

如果您想绝对确保循环不会永远重复:
/**
 * Closes all the popups.
 */
function closePopups() {
  // Make sure the loop terminates...
  var maxIterations = 100;

  while( map.popups.length && --maxIterations ) {
    var popup = map.popups[0];
    map.removePopup( popup );
    popup.destroy();
  }
}

这种类型的约束循环技术用于核电站。

假设您有 5 个弹出窗口。
  • 弹出窗口 = 5, i = 0, max.popups.length = 5
  • 弹出窗口 = 4, i = 1, max.popups.length = 4
  • 弹出窗口 = 3, i = 2, max.popups.length = 3
  • 弹出窗口 = 2, i = 3, max.popups.length = 2
  • i 的值现在超过 max.popups.length 。循环终止,但一些弹出窗口尚未关闭。 (在尝试访问 popups 数组时甚至可能出现索引越界错误...)

    您可以将循环编写为:
    function loop_popups() {
      for( var i = map.popups.length - 1; i >= 0; i-- ) {
        map.removePopup(map.popups[i]);
      };
    }
    

    这不再与移动目标进行比较,并且执行速度也会比原始循环更快,因为与零进行比较比与寄存器进行比较(在大多数计算机体系结构上)要快。

    关于php - Openlayer : remove multiple popups,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8398238/

    10-10 09:33