use*_*303 3 html javascript css jquery svg
我有一个像下面这样的 div,里面有一个问号...
<div id="mydiv">?</div>
Run Code Online (Sandbox Code Playgroud)
在我的代码中,当有人尝试提交表单时,我会检查该字段中是否有问号,如下所示:
const fieldText = $('#mydiv').text();
return fieldText.indexOf('?') !== -1;
Run Code Online (Sandbox Code Playgroud)
这很好用,但是现在,我有一个问号(而不仅仅是文本问号)的 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>
Run Code Online (Sandbox Code Playgroud)
我仍然想检查那个 div,但现在我必须检查它是否有 SVG,而不仅仅是“?”。如何使用 JS 检查 div 中是否有 svg 元素?
仅供参考,我尝试了以下操作,因为我认为它仍然会查找文本,但无济于事......
const fieldText = $('#mydiv').text();
return fieldText.indexOf('svg') !== -1;
Run Code Online (Sandbox Code Playgroud)
jQuery 在这里有点矫枉过正。您可以使用 vanilla 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');
}Run Code Online (Sandbox Code Playgroud)
<div id='test1'></div>
<div id='test2'><svg></svg></div>Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3598 次 |
| 最近记录: |