引导下拉切换不适用于包装在对象标签中的 svg



当我将我的 svg 内联放入 html 并在其中放置一个下拉切换类时,它运行良好。但是当我用对象标签包装它时,它会显示 svg 本身,但当我单击它时,它不会显示下拉菜单,或者很快 - 它不起作用。

以下是适用于内联 svg 的代码:

<div class="dropdown pull-left">
    <svg class="sidebar-icon-size notifications-icon dropdown-toggle" 
         data-toggle="dropdown" version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
         viewBox="0 0 12.7 14" style="enable-background:new 0 0 12.7 14;" xml:space="preserve">
        <path d="M6.1,9.5c-1.6,0.6-2.7,1.3-3.4,1.9c0.5,0.5,1.5,0.6,2.4,0.2c1.2-0.4,1.9-1.5,1.7-2.3c0,0,0,0,0,0C6.5,9.3,6.3,9.4,6.1,9.5
            M7.1,12.2c-3.1,1.1-5.6,0.5-5.7,0.2c-0.2-0.5,1-2.2,4.5-3.5c3.5-1.3,5.5-0.8,5.7-0.2C11.7,9,10.1,11.1,7.1,12.2 M10,5.8
            C8.2,1.9,7.3,0.5,4.3,0.5c-1.1,0-0.8-0.8-1.6-0.5C1.9,0.4,2.6,0.8,1.8,1.5c-2.3,1.9-2.1,3.6-1,7.8c0.4,1.7-1.1,1.8-0.5,3.5
            C0.7,14,4,14.5,7.4,13.3c3.4-1.3,5.6-3.8,5.2-5C12,6.5,10.8,7.5,10,5.8" />
    </svg>
    <ul class="topbar-menu dropdown-menu pull-right" style="width:200px;">
        <li>blabla 1</li>
        <li>blabla 2</li>
        <li>blabla 3</li>
    </ul>
</div>

以下是不适用于包装器对象标签的代码:

<div class="dropdown pull-left">
    <object class="topbar-icon-size notifications-icon dropdown-toggle"
                            data-toggle="dropdown" 
                            data="../../Styles/Icons/Notifications.svg"
                            type="image/svg+xml"></object>
    <ul class="topbar-menu dropdown-menu pull-right" style="width:200px;">
        <li>blabla 1</li>
        <li>blabla 2</li>
        <li>blabla 3</li>
    </ul>
</div>

我尝试从对象标签中删除下拉切换类和数据切换属性,以便它们仅保留在 svg 文件中,反之亦然,将它们从 svg 文件中删除并仅将它们放在对象标签中,我尝试了当它们都在两者上时,但无论如何它都不起作用。任何帮助将不胜感激。谢谢:)

我怀疑原因可能是由于与单击<object>元素相关的浏览器安全限制。

请尝试改用<img>

<div class="dropdown pull-left">
    <img class="topbar-icon-size notifications-icon dropdown-toggle"
                            data-toggle="dropdown" 
                            src="../../Styles/Icons/Notifications.svg"/>
    <ul class="topbar-menu dropdown-menu pull-right" style="width:200px;">
        <li>blabla 1</li>
        <li>blabla 2</li>
        <li>blabla 3</li>
    </ul>
</div>

当我使用 pointer-events: none 到 SVG 元素时,它对我有用。我总是将点击事件注册到父元素(但不直接注册到 SVG 元素(

最新更新