所以我有一个 XSLT 表单,它从 XML 表单获取数据并将其显示给我。我想通过类名获取元素的值,但它一直返回未定义。这是 XSLT 代码的片段
<!-- generic input template -->
<xsl:template match="DataField" priority="0">
<td colspan="{DisplayOptions/@ColSpan}" location="{DisplayOptions/@Column}">
<xsl:value-of select="FieldOptions/@DisplayName"/>
<br/>
<input type="{@ControlType}" name="{@Name}" onchange="textBlur(event)" />
<xsl:apply-templates select="SubDataFields"/>
</td>
</xsl:template>
我尝试过的两种方法是 jquery 和使用文档
function textBlur(e) {
//this gives me the value and works
var personInfo = e.target.value;
var personField = e.target.name;
//these two return undefined
var elements = document.getElementsByClassName("personField");
console.log($(elements).val());
console.log($("."+personField).val());
}
我在这里做错了什么?personField 是我想要的元素的名称。由于 XSLT 为我生成了类名。所以我所做的是使用事件来获取元素的名称和值,以确认我使用了正确的名称并且正在获取一个值,然后我尝试使用 jquery 和名称再次获取元素的值。