javascript - 将 jQuery 事件与 Raphael/Mapael 链接在一起

标签 javascript jquery svg raphael mapael

我正在使用 Mapael,这是一个用于创建交互式 map 的 Raphael 插件。我希望在单击时为 map 的一个区域着色,然后在再次单击该区域时将其恢复为默认颜色。这是一个 plnk;

http://plnkr.co/edit/VNUYsO0TeX7AIdLqLjiG

如您所见,您只能单击 map 的一部分。然而,问题是当您使用列表项时。我想让这两个功能一起工作,这样 map 上在任何时候都只能有一个区域显示为绿色。

这是我认为需要更改的代码;

JavaScript:

 var green = "#9FCC3B";
 var grey = "#ededed";
 var previousSelectedElementId = null;

  $("ul#countries li a").click(function() {
    var updatedOptions = {
        'areas': {}
      },
      inputVal = $(this).attr("map")

    if (previousSelectedElementId !== null) {
      updatedOptions.areas[inputVal] = {
        attrs: {
          fill: grey
        }
      }

    }

    if (inputVal) {
      updatedOptions.areas[inputVal] = {
        attrs: {
          fill: green
        }
      };
      previousSelectedElementId = inputVal;
    } else {
      updatedOptions.areas[inputVal] = {
        attrs: {
          fill: grey
        }
      };
      previousSelectedElementId = null;
    }


    $(".mapcontainer").trigger('update', [updatedOptions, {},
      []
    ]);

    $("#selectCountry").html($(this).text())
  });

HTML:

<ul>
    <li><a href="#" id="selectCountry">France</a>
      <ul id="countries">
        <li><a href="#" map="BE">Belgium</a></li>
        <li><a href="#" map="FR">France</a></li>
        <li><a href="#" map="NL">Netherlands</a></li>
      </ul>
    </li>
  </ul>

目前,当一个列表项被点击时,它会获取与 map.js 文件中的路径标识符相同的 map 属性,然后使用 updatedOptions 来执行颜色更改。

我不确定我是否可以重用 previousSelectedElementId 来复制与点击事件一起使用的相同功能?

希望我已经充分解释了问题,如果需要更多信息,我可以根据需要提供。

干杯


编辑:

我一直在研究它,并考虑将选择链接到隐藏的文本框并使用 .one 处理程序的可能性?不幸的是我无法让它工作,但如果有人认为这个想法是一个可行的选择,这里是一个 plnk;

http://plnkr.co/edit/4dskLo0w1XZkPckyE61z?p=info

(当您手动输入('FR'、'NL'、'BE' 等)时有效

最佳答案

我找到了类似这样的解决方案 您将其添加到 Mapael 中的点击功能中。您在整个 mapael 函数之外将 previousSelectedElementId 定义为 null。它并不完全符合您的要求,但非常接近。

if (previousSelectedElementId !== null) {
    newData.areas[previousSelectedElementId] = {
        attrs: {
            fill: "rgba(255,255,255,0.3)"
        }
    };
}

if (mapElem.originalAttrs.fill == "rgba(255,255,255,0.3)") {
    newData.areas[id] = {
        attrs: {
            fill: "rgba(0,0,0,1)"
        }
    };
    previousSelectedElementId = id;
} else {
    newData.areas[id] = {
        attrs: {
            fill: "rgba(255,255,255,0.3)"
        }
    };
    previousSelectedElementId = null;
}

$(".world").trigger('update', [{mapOptions: newData}]);

关于javascript - 将 jQuery 事件与 Raphael/Mapael 链接在一起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37342374/

相关文章:

javascript - 更改 Geocoder.geocode() 返回结果的语言

javascript - 如何使用 nodejs-iconv 模块(或其他解决方案)在 nodejs javascript 中将字符编码从 CP932 转换为 UTF-8

javascript - 包装列表项以创建嵌入列表

jquery - 将图像的一部分变灰

php - 数据百分比卡住了

javascript - 如何实现 `$locationProvider.html5Mode(true);

javascript - 每次 ember 应用程序中的 url 更改时,火路由/ Controller 都会 Hook

javascript - 如何使用 jquery 动态地给标题和日期时间属性

javascript - 使用 springy.js 加载多个图形时 Canvas 闪烁

html - 使用 svg 和 html 缩放和定位