我有一个像下面这样的div,里面有一个问号...
<div id="mydiv">?</div>
在我的代码中,当有人尝试提交表单时,我进行检查以查看该字段中是否带有问号,例如:
const fieldText = $('#mydiv').text();
return fieldText.indexOf('?') !== -1;
效果很好,但现在,我有了一个问号的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>
我仍然想对该div进行检查,但是现在我必须检查它是否包含SVG,而不仅仅是“?”。如何使用JS检查div中是否包含svg元素?
仅供引用,我尝试了以下操作,因为我认为仍然可以查找该文本,但无济于事...
const fieldText = $('#mydiv').text();
return fieldText.indexOf('svg') !== -1;
最佳答案
jQuery在这里过大了。您可以使用普通javascript和getElementsByTagName
返回特定元素中的匹配元素的数组。然后,您可以针对返回数组的长度进行测试(条件中的0用作false)。
例如两项测试,一项在div中使用svg,一项不包含:
var t1 = document.getElementById('test1');
var t2 = document.getElementById('test2');
// Used in a simple conditional statement
if (t1.getElementsByTagName('svg').length) {
console.log('test1 has svg');
}
if (t2.getElementsByTagName('svg').length) {
console.log('test2 has svg');
}
<div id='test1'></div>
<div id='test2'><svg></svg></div>