4

好的,我正在尝试捕获菜单项上的点击事件

这是我的html:

<nav>
<ul>
    <li class="active left" id="profileLink">
        <object type="image/svg+xml" data="public/img/nav/profile.svg">    
                <img src="public/img/nav/profile.png" alt="Blue Square"/>     
        </object>
    </li>
    <li class="left" id="suggestionsLink">
        <object type="image/svg+xml" data="public/img/nav/suggestions.svg">    
                <img src="public/img/nav/suggestions.png" alt="Blue Square"/>     
        </object>
    </li>
    <li class="right" id="settingsLink">
        <object type="image/svg+xml" data="public/img/nav/settings.svg">    
                <img src="public/img/nav/settings.png" alt="Blue Square"/>     
        </object>
    </li>
    <li class="right" id="statisticsLink">
        <object type="image/svg+xml" data="public/img/nav/statistics.svg">    
                <img src="public/img/nav/statistics.png" alt="Blue Square"/>     
        </object>
    </li>

    <li class="middle" id="friendsLink">
        <object type="image/svg+xml" data="public/img/nav/friends.svg">    
                <img src="public/img/nav/friends.png" alt="Blue Square"/>     
        </object>
    </li>
</ul>

这是我正在使用的脚本:

    $("#wrapper").on("click", '#friendsLink', function(){
       console.log('test');
       loadFriends();
    });

当我使用脚本选择一个普通的 a-tag 时,它工作得很好,但在这个 svg 对象上它根本不起作用。请注意,单击 li 元素的填充区域时它确实有效。但不是在单击 svg 图像区域时。

此线程中的帖子表明 svg dom 与 html dom 不同,因此 jquerys 事件失败。

jQuery 选择器 + SVG 不兼容?

尝试处理 svg 元素上的点击事件时该怎么办?

非常感谢您的帮助

4

1 回答 1

3

如果您想使用<object>,您必须将点击处理放在 svg 内容上,即<svg>public/img/nav/profile.svg 等的根元素。

如果要保持原样处理,则需要使用<image>元素作为<svg>容器而不是<object>元素。这有其自身的限制,例如没有脚本和回退。

第三种选择可能是在每个 svg 元素上放置一个绝对定位的透明 div,并在其上处理 onclick。

您必须选择最适合您需求的解决方案。

于 2012-11-05T19:23:30.587 回答