そのため、10 ~ 12 年前のコードを Chrome と互換性を持つように更新する作業を行っていますが、既に行き詰まっています。なんらかの理由で、数字を入力して「fillPO」ボタンをクリックすると、何も更新されず、代わりに「null」がボックスに入力されます。これは Internet Explorer で意図したとおりに機能します。これをクロムで動作させるための一般的なルールはありますか?
<xsl:template name="control-row">
<xsl:if test="$orderApprove='true' and $isSuperUser='false' and $archiveView='false' ">
<td nowrap="true" colspan="10">
<input type="button" name="servlet" value="Approve" onClick="return approveOrder();"> checked orders</input>
<xsl:if test="/poursxml/OrderedFields/Field='PO'">
Fill PO number across orders:
<input type="text" name="genericPO" id = "genericPO" size="15" maxlength="30"/>
<input type="button" value=" Fill PO " onclick="fillPO()"/>
</xsl:if>
</td>
</xsl:if>
</xsl:template>
これは、javascript の fillPO() です。
function fillPO()
{
if(!anySelected())
alert('Please select an order first.');
else
{
dfa = document.getElementsByName('orderNumber');
len = dfa.length;
var ix = 0;
for(ix=0; ix<len; ix++)
{
if(dfa[ix].name == 'orderNumber')
{
if(dfa[ix].checked == true)
{
el_id = dfa[ix].id;
position = el_id.substring(11);
document.getElementById('PONumber' + position).innerHTML = '<input size="15" maxlength="30" type="text" name="PONumber" value="' + document.getElementById('genericPO').getAttribute('value') + '"></input>';
}
}
}
}
}