如何使用JavaScript检查div中是否包含svg?

如何使用JavaScript检查div中是否包含svg?,javascript,jquery,html,css,svg,Javascript,Jquery,Html,Css,Svg,我有一个类似下面的div,里面有一个问号 <div id="mydiv">?</div> 这很好,但是现在,我有了一个问号的SVG(而不仅仅是文本问号),而不是那个div中的问号,如下所示 <div id="mydiv"> <svg version='1.1' id='Layer_1' class='q-mark-svg' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.o

我有一个类似下面的div,里面有一个问号

<div id="mydiv">?</div>
这很好,但是现在,我有了一个问号的SVG(而不仅仅是文本问号),而不是那个div中的问号,如下所示

<div id="mydiv">
  <svg version='1.1' id='Layer_1' class='q-mark-svg' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 50 50' style='enable-background:new 0 0 50 50;' xml:space='preserve'>
    <style type='text/css'>
      .q-mark{fill:#777777;}
    </style>
    <g>
      <g>
        <path class='q-mark' d='M18.3,17.2c0,0.4-0.1,0.7-0.2,1c-0.1,0.3-0.3,0.6-0.5,0.8c-0.2,0.2-0.5,0.4-0.8,0.5c-0.3,0.1-0.6,0.2-1,0.2 c-0.7,0-1.3-0.2-1.8-0.7c-0.5-0.5-0.7-1.1-0.7-1.8c0-1.6,0.3-3.2,0.9-4.6c0.6-1.4,1.5-2.7,2.6-3.8s2.3-1.9,3.8-2.5 c1.4-0.6,3-0.9,4.6-0.9s3.1,0.3,4.6,1c1.4,0.6,2.7,1.5,3.8,2.6s1.9,2.3,2.6,3.8c0.6,1.4,0.9,2.9,0.9,4.5c0,3.2-1.2,6-3.5,8.4 l-3.8,3.5c-1.3,1.3-2,2.7-2,4.3c0,0.7-0.2,1.3-0.7,1.8c-0.5,0.5-1.1,0.7-1.8,0.7s-1.3-0.2-1.8-0.7c-0.5-0.5-0.7-1.1-0.7-1.8 c0-2.9,1.2-5.6,3.5-7.9l3.8-3.6c1.3-1.4,2-2.9,2-4.8c0-0.9-0.2-1.8-0.5-2.6c-0.4-0.8-0.8-1.5-1.5-2.1c-0.6-0.6-1.3-1.1-2.1-1.5 c-0.8-0.4-1.7-0.5-2.6-0.5c-0.9,0-1.8,0.2-2.6,0.5c-0.8,0.4-1.5,0.8-2.1,1.4c-0.6,0.6-1.1,1.3-1.4,2.1 C18.5,15.3,18.3,16.2,18.3,17.2z M28.5,40.9c0,1-0.3,1.8-1,2.5c-0.7,0.7-1.5,1-2.5,1c-1,0-1.8-0.3-2.5-1c-0.7-0.7-1-1.5-1-2.5 c0-1,0.3-1.8,1-2.5c0.7-0.7,1.5-1,2.5-1c1,0,1.8,0.3,2.5,1C28.2,39.1,28.5,40,28.5,40.9z'/>
      </g>
    </g>
  </svg>
</div>
使用
document.querySelector(“#mydiv svg”)!==空


document.querySelector(“mydiv svg”).querySelector(“svg”)!=null

试试这个
$(“#mydiv”).find('svg').length)

如果存在svg
svg
,则将长度作为某个值,如果不存在,则该值将为0


希望这对您有所帮助。

在div中查找
svg
标记。
if($(“#mydiv”).find(“svg”).length){
警惕(“我发现了SVG”);
}否则{
警报(“未找到SVG”);
}

.q-标记{填充:#777777;}

jQuery在这方面做得太过分了。您可以使用vanilla javascript和
getElementsByTagName
返回特定元素内部的匹配元素数组。然后可以根据返回数组的长度进行测试(0在条件中充当false)

例如两个测试,一个在div中带有svg,另一个没有:

var t1=document.getElementById('test1');
var t2=document.getElementById('test2');
//用于简单的条件语句中
if(t1.getElementsByTagName('svg').length){
log('test1有svg');
}
if(t2.getElementsByTagName('svg').length){
log('test2有svg');
}

您可以尝试以下方法:

if($("svg")[0]){
    console.log("present");
} else { 
    console.log("absent");
}

这不也是在文本体而不是标记中匹配svg吗?@Jesin浏览文本将比
HTML
tags更匹配文本不管怎样,事实证明
find
是一种jQuery方法,可以完成这里需要的功能,虽然比
querySelector
慢得多。但这是否也与文本体中的svg而不是标记匹配?我的否决票是一个错误。StackOverflow不会让我更改我的投票,直到您进行一个小的编辑,比如在开始时将“Find”更改为“Find an”。
const fieldText = $('#mydiv').text();
return fieldText.indexOf('svg') !== -1;
if($("svg")[0]){
    console.log("present");
} else { 
    console.log("absent");
}