$.post投掷”;非法调用”;

$.post throwing "Illegal invocation "

本文关键字:调用 非法 post 投掷      更新时间:2024-06-14

编辑:到目前为止,所有建议的答案都不起作用。

我正在和姜戈通话。第一次运行时,服务器返回"n_usr"(这会更改用户文件的格式)。第二次,它只是抛出一个Illegal invocation错误。

function log_in () {
        username = $('#usr_enter').val();
        password = $('#pass_enter').val();
        if(!n_usr){
            $.post('/ajax/login',{password: password, username: username}, function(data) {
              if(data == "n_usr"){
                $('#new_user_entry').show('slow');
                n_usr = true;
              }
              else {
              }
            })
    }else {
        password2 = $('#pass_re_enter');
        penname = $('#pen_enter');
            $.post('/ajax/login', {password: password, password2: password2, username: username, pen_name: penname, TN: "TN"}, function(data) {
                if(data == "e_act"){
                } else {
                }
            });
        }
    }

else中,您有:

password2 = $('#pass_re_enter');
penname = $('#pen_enter');

然后你有:

{password: password, password2: password2, username: username, pen_name: penname, TN: "TN"}

您得到Illegal invocation是因为jQuery正试图序列化$.post的jQuery对象,但它做不到。它可能试图调用一个字符串方法,并将一个jQuery对象作为上下文传递给它,从而导致错误。

您需要添加.val()

password2 = $('#pass_re_enter').val();
penname = $('#pen_enter').val();

好吧,你对它们的调用不同——第一次:

 $.post(url_base+'/ajax/login' ...

和第二个

  $.post('/ajax/login', {....

将第二个更改为包含url_base。