21

我正在其中一个事件中创建用户输入:

var throwConnectBox = function() {
    chat_box = document.getElementById('box');
    div = window.parent.document.createElement('div');
    input = window.parent.document.createElement('input');
    input.type = "submit";
    input.value = "Join chat";
    input.onclick = "conn.send('$connect\r\n');";
    div.appendChild(input);
    chat_box.appendChild(div);
}

...但生成的输入没有 onclick 属性。我试着用

    input.onclick = conn.send('$connect\r\n');

...相反,但也没有工作。我究竟做错了什么?

4

4 回答 4

38

试试这个:

 input.onclick = function() { conn.send('$connect\r\n'); };

史蒂夫

于 2009-04-25T22:20:30.033 回答
6

您的其中一条线路有问题;我已经为你更正了:

 var throwConnectBox = function() {
     chat_box = document.getElementById('box');
     div = window.parent.document.createElement('div');
     input = window.parent.document.createElement('input');
     input.type = "submit";
     input.value = "Join chat";
     /* this line is incorrect, surely you don't want to create a string? */
     // input.onclick = "conn.send('$connect\r\n');";?
     input.onclick = function() { 
         conn.send('$connect\r\n'); 
     };
     div.appendChild(input);
     chat_box.appendChild(div);
 }

这更有意义吗?

于 2009-04-25T22:28:33.587 回答
2

我想你可能想逃避 \r\n,如果你打算通过这些......

conn.send('$connect\\r\\n')

我不太明白你的 onclick 处理程序试图实现什么......

于 2009-04-25T22:21:34.557 回答
1

这是我决定使用 jQuery 的原因之一:

 $('<input type="submit" value="Join chat" />')
      .click( function() { conn.send('$connect\r\n'); } )
      .appendTo('<div></div>')
      .appendTo('#box');
于 2009-04-25T22:59:47.320 回答