4

これは私の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関数を呼び出すだけです。

手伝ってくれますか?

4

2 に答える 2

3

document.getElementById("txt").onchange();コードを介して値を変更した後、を使用してコードからonchangeを起動できます

アップデート

テキストボックスのIDを取得するように集合関数を変更します

function set(textboxid)
{
    var tb = document.getElementById(textboxid);
    tb.value++;
    tb.onchange();
}
于 2010-08-30T13:21:00.920 に答える
0

これはブラウザのバグのようです。firebugを使用して、すべてのイベントを入力に記録しました。関数set()を使用して値を変更すると、すべてのイベントがトリガーされます。

Firefoxでテストしました。


注:それがバグではない場合、少なくともイベントがどのように機能するかについての間違った定義です。

于 2010-08-30T13:45:39.210 に答える