Why is FBJS dropping my 'onclick' attribute from this input element?

Posted by Chris Barnhill on Stack Overflow See other posts from Stack Overflow or by Chris Barnhill
Published on 2009-10-14T01:26:00Z Indexed on 2010/05/22 13:10 UTC
Read the original article Hit count: 247

Filed under:
|
|
|

When I include an 'onClick' attribute in setInnerXTHML() like this:

var innerHtml = '<span>Build Track: Select a city where track building should begin'+
                '<div id="action-end">'+
                '<form>'+
                '<input type="button" value="End Track Building" id="next-phase" onClick="moveTrainAuto();" />'+
                '</form>'+
                '</div></span>';
actionPrompt.setInnerXHTML(innerHtml);
var btn = document.getElementById('next-phase');
btn.addEventListener('click', 'moveTrainAuto');

The 'onClick' gets dropped. I know this from inspecting the element with Firebug. This is what it reveals:

<input id="app148184604666_next-phase" type="button" value="End Track Building"/>

Here is the function called for onClick:

function moveTrainAuto(evt) {
debugger;
  ajax = new Ajax();
  ajax.responseType = Ajax.JSON;
  ajax.ondone = function(data) {
debugger;
    if(data.code == 'UNLOAD_CARGO') {
      unloadCargo();
    } else if (data.code == 'MOVE_TRAIN_AUTO') {
      moveTrainAuto();
    } else if (data.code == 'TURN_END') {
      turnEnd();
    } else {
      /* handle error */
    }
  }
  ajax.post(baseURL + '/turn/move-trains-auto');
}

As you can see, I've tried both 'onClick' and 'addEventListener'. Neither works. Any ideas?

© Stack Overflow or respective owner

Related posts about JavaScript

Related posts about events