将数据分配给输入文本框时,不会触发输入文本框onchange

时间:2010-08-30 13:17:47

标签: html textbox onchange

这是我的HTML页面

<script>
function set()
{
document.getElementById("txt").value++;
}
</script>
<input id="txt" type="text" onchange="javascript:alert('txt changed');" value="0">
<br/>
<input type="button" onclick="set()" value="Set Data"/>

当我按下按钮时,文本框值正在改变,并且onchange事件未触发, 但是当我在文本框中手动输入值时,它会触发onchange。

我想要的是在单击按钮时在文本框中更改数据时调用JavaScript函数。

你能帮忙吗?

2 个答案:

答案 0 :(得分:3)

您可以在通过代码

更改值后使用document.getElementById("txt").onchange();从代码触发更改

<强>更新

更改您的设置功能以获取文本框的ID

function set(textboxid)
{
    var tb = document.getElementById(textboxid);
    tb.value++;
    tb.onchange();
}

答案 1 :(得分:0)

这似乎是一个浏览器错误。使用firebug,我记录了输入中的所有事件。使用函数set();

更改值时会触发任何事件

我在firefox中测试过。


注意:如果它不是错误,至少是关于事件如何工作的错误定义。