gpt4 book ai didi

javascript - 使用javascript将文本节点添加到SVG组但没有出现

转载 作者:行者123 更新时间:2023-11-30 13:05:14 26 4
gpt4 key购买 nike

这是 SVG 文件中标记内的 Javascript。

此 SVG 显示了我所在城市的乐队时间表。当鼠标单击 时,脚本会访问 XML 库并检索每个乐队中成员加入时的姓名。并向包含 .

的 SVG 组添加一个新的文本节点

这是第一个:

   <g class="band" id="hajimama">
<text x="633.333333333" y="50" fill="black" font-size="12">Hajimama</text>
<rect x="633.333333333" y="50" width="413.333333333" height="15" fill="red" onmousedown="growBox(evt);"></rect></g>

这是 growBox() 函数:

    function growBox(evt)
{
var i, g_index;
var r = evt.target;

g_index = find_SVGBand(r);

b = find_XMLBand(b_name);
members = b.getElementsByTagName("member"); //members.length is used for drawing.
stretch = members.length*16;

for (k=g_index+1;k<groups.length;k++)
{
cur_y = parseFloat(get_firstChild(groups[k]).getAttribute("y"));
new_y = cur_y + stretch;
get_firstChild(groups[k]).setAttribute("y",new_y);
groups[k].getElementsByTagName("rect")[0].setAttribute("y",new_y);
}
evt.target.setAttribute('height',stretch);

var s = parseFloat(r.getAttribute("y")) + 5; //write the first member name below the band name
for (k=0;k<members.length;k++) //loop through each member of a band
{
var m=members[k];
var m_name = returnMemberName(m);

q = document.createElement("text");
q.setAttribute("font-size",20);

if (m.getElementsByTagName("instrument")[0].hasChildNodes())
{
if (m.getElementsByTagName("instrument")[0].childNodes[0].nodeValue == "guitar")
inst_clr="#993333";
else if (m.getElementsByTagName("instrument")[0].childNodes[0].nodeValue == "bass")
inst_clr="#339933";
else if (m.getElementsByTagName("instrument")[0].childNodes[0].nodeValue == "drums")
inst_clr="#333399";
}
else
inst_clr="#000000";

q.setAttribute("fill",inst_clr);

//draw names based on start dates
m_start = returnMemberJoinDate(m);
mrect_start = (m_start - 2000) * 80;

q.setAttribute("x",mrect_start);
q.setAttribute("y",s);
mn = document.createTextNode(m_name);
q.appendChild(mn);
r.parentNode.appendChild(q);
q.setAttribute('visibility','visible');
s+=15;
alert(r.parentNode.getAttribute("id") + " " + get_lastChild(r.parentNode).nodeName + " " + get_lastChild(r.parentNode).childNodes[0].nodeValue);
} //for

evt.target.setAttribute('onmousedown','');
addEBox(evt);
}

正如您通过 alert() 看到的那样,数据被正确访问并且节点被正确附加到节点,因为 r.parentNode.getAttribute("id") 返回节点的 ID。

为什么文本没有出现有什么想法吗?

谢谢。

最佳答案

在 SVG 中,元素必须在 SVG 命名空间中创建。这意味着 createElement 不会创建 SVG 文本元素,您需要 createElementNS 代替。

所以

q = document.createElement("text");

应该是

q = document.createElementNS("http://www.w3.org/2000/svg", "text");

关于javascript - 使用javascript将文本节点添加到SVG组但没有出现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15926356/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com