jQuery SVG:克服类操作障碍
将 jQuery 合并到 SVG 操作中可以简化开发。然而,遇到的一个常见陷阱是无法从 SVG 元素添加或删除类。让我们深入研究问题并探索解决方案。
问题:
尝试使用 jQuery 操作 SVG 元素中的类时,通常会失败。例如,考虑以下代码:
<svg> <rect>
在此示例中,jQuery 代码应在单击时将“clicked”类添加到矩形。然而,它失败了。
解决方案:
1.使用 JQuery 3 或更高版本:
3 之前的 JQuery 版本在使用 SVG 类时遇到困难。不过,这个问题在 JQuery 3 及更高版本中已得到解决。升级到最新的 JQuery 版本应该可以解决该问题。
2.使用 Vanilla JavaScript:
如果您不想依赖 JQuery,则可以使用 vanilla JavaScript 直接操作 SVG 类。 classList.add() 方法提供了一种方便的方法来实现此目的:
var element = document.getElementById("p5"); element.classList.add("clicked");
3.利用 .attr() 方法:
另一种选择是使用 .attr() 方法,该方法与 jQuery 和 vanilla JavaScript 兼容:
// jQuery $("#p5").attr("class", "clicked"); // Vanilla JavaScript element.setAttribute("class", "clicked");
通过利用作为这些解决方案之一,您可以使用 jQuery 或 vanilla JavaScript 有效地操作 SVG 元素中的类,从而克服以前的限制。
以上是为什么 jQuery 不操作 SVG 类,如何修复它?的详细内容。更多信息请关注PHP中文网其他相关文章!