我试图创建一个AJAX请求。下面是我的函数定义:

function AJAXrequest(url, postedData, callback) {
    $.ajax({
        type: 'POST',
        url: url,
        data: postedData,
        dataType: 'json',
        success: callback
    });
}

这里是我调用它的地方,提供参数:

AJAXrequest('voting.ajax.php', data, function(data) {
    // function body
});

然而回调没有运行,相反,我得到一个console.error:

TypeError: $.ajax(...) is not a function.

Why?


当前回答

不确定,但看起来你的代码中有一个语法错误。试一试:

$.ajax({
  type: 'POST',
  url: url,
  data: postedData,
  dataType: 'json',
  success: callback
});

$旁边有额外的括号。这些都是不需要的。如果仍然得到错误,则不会加载jQuery脚本文件。

其他回答

这可能是因为JQuery的精简构建。尝试使用“未压缩”或“缩小”版本。JQuery (cdn) 这也可能是因为在JQuery CDN之前加载了Bootstrap CDN。在我的例子中,我删除了Bootstrap CDN,并将JQuery移动到'body'标签的末尾,问题就解决了。

我使用以下版本的jQuery和它的工作

<script src="https://code.jquery.com/jquery-3.3.1.min.js"
    integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script>

我遇到了同样的问题,我的解决方案是:添加JQuery脚本。

特别是,我们应该确保在firefox/chrome下调试js时加载了相应的JQuery。

不要使用jQuery的精简版本,它没有ajax功能。请使用https://releases.jquery.com/上的简化版本

注意:请确保不要使用从Bootstrap网站复制的jquery链接,因为他们使用的是精简版。

引用包含ajax的jquery最小版本:

<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>