TypeError:'stepUp'调用未实现接口HTMLInputElement的对象

Sto*_*one 31 ajax jquery

我在使用AJAX时出错:

TypeError:'stepUp'调用一个没有实现接口HTMLInputElement的对象.... plete",[C,p]), - x.active || x.event.trigger("ajaxStop")))}返回C}的getJSON:functi ...

以下是我使用它的代码部分:

<script src="http://code.jquery.com/jquery-1.10.1.min.js"></script>
Run Code Online (Sandbox Code Playgroud)

这是我的javascript代码,适用于我之前定义它们的复选框:

function feedback() {
    var boxes = document.getElementsByClassName('box');
    for (var j = 0; j < boxes.length; j++) {
        if (boxes[j].checked) {
            //assign(1);
            assign = 1;
        } else {
            assign = 0;
            //assign(0);
        }
        var wordid = document.getElementsByClassName('wordId')[j];
        $.ajax({
            url: "assigner.php",
            type: "POST",
            data: {
                wordid: wordid,
                assign: assign
            }
        }).done(function(e) {
            /*alert( "word was saved" + e );*/
        });
    }
}
Run Code Online (Sandbox Code Playgroud)

我试过这个,但它不起作用,它不会给我任何错误.

var newvalue = '';
$('input[name=wordid\\[\\]]').each(function(index, element) {
    newvalue = newvalue + this.value + ',';
});
$.ajax({
    url: "assigner.php",
    type: "POST",
    data: {
        wordid: newvalue,
        assign: assign
    }
}).done(function(e) {
    /*alert( "word was saved" + e );*/
});
Run Code Online (Sandbox Code Playgroud)

Ror*_*san 70

$.ajax并不期望HTMLInputElement您传递给的对象中有DOMElement类型data.尝试只给它字段的值:

var wordid = $('.wordId').val();
$.ajax({
    url: "assigner.php",
    type: "POST",
    data: { wordid: wordid, assign: assign}
}).done(function( e ) {
    /*alert( "word was saved" + e );*/
});
Run Code Online (Sandbox Code Playgroud)

  • 好的解决方案 它通过阅读第一行的前几个单词解决了我的问题;) (5认同)
  • @Rory:你是个天才. (2认同)