javascript - The "onchange" event does not work with "value" change in "text input&

I have a JavaScript input object with type="text" ing along with an onchange event which is c

I have a JavaScript input object with type="text" ing along with an onchange event which is created by (related lines):

var id_box = document.createElement('input');
id_box.id = 'id_box';
id_box.type = 'text';
id_box.onchange = function()
{
    alert("Changed!");
}

For changing this value in this input field I use:

var a = document.createElement('a');
a.innerHTML = "A";
a.onclick = function()
{
    document.getElementById('id_box').value = 'A';
}

The onchange event works only changing value by keyboard typing but not for changing value by above function. Is there any way to make this works?

Please take a look at this: /

I have a JavaScript input object with type="text" ing along with an onchange event which is created by (related lines):

var id_box = document.createElement('input');
id_box.id = 'id_box';
id_box.type = 'text';
id_box.onchange = function()
{
    alert("Changed!");
}

For changing this value in this input field I use:

var a = document.createElement('a');
a.innerHTML = "A";
a.onclick = function()
{
    document.getElementById('id_box').value = 'A';
}

The onchange event works only changing value by keyboard typing but not for changing value by above function. Is there any way to make this works?

Please take a look at this: http://jsfiddle/zCMdV/7/

Share Improve this question edited Jan 13, 2023 at 14:34 Brian Tompsett - 汤莱恩 5,89372 gold badges61 silver badges133 bronze badges asked Jul 26, 2011 at 7:32 ProtocoleProtocole 1,74311 gold badges28 silver badges43 bronze badges 0
Add a ment  | 

1 Answer 1

Reset to default 8

What browser are you using?

I have made this example, which works for me... the subtle change is that I add the event to the input before I append it to the div element.

<div id="test"></div>
<script type="text/javascript">
    var id_box = document.createElement('input');
    id_box.type = 'text';
    id_box.onchange = function()
    {
        alert("Changed!");
    }
    document.getElementById("test").appendChild(id_box);

</script>

See it in action on JS Fiddle: http://jsfiddle/Sohnee/zCMdV/

Update:

If you are going to automate the changing of the value, you can do the same to trigger the change event...

http://jsfiddle/Sohnee/zCMdV/10/

document.getElementById('id_box').onchange();

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1743585857a4474944.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信