jQuery.ajax 在 ie 中使用“删除”方法的问题

IT技术 javascript jquery ajax internet-explorer
2021-02-27 13:30:27

我有一个页面,用户可以在其中使用按钮编辑各种内容并选择触发 ajax 调用的内容。特别是,一个操作会导致远程调用 url,其中包含一些数据和“放置”请求,这(因为我使用的是宁静的 Rails 后端)触发我的更新操作。我还有一个删除按钮,它调用相同的 url 但带有“删除”请求。“更新”ajax 调用适用于所有浏览器,但“删除”调用不适用于 IE。我之前遇到过这样的事情,我有一个模糊的记忆......任何人都可以透露任何信息吗?这是我的 ajax 调用:

//update action - works in all browsers
jQuery.ajax({
  async:true, 
  data:data, 
  dataType:'script', 
  type:'put', 
  url:"/quizzes/"+quizId+"/quiz_questions/"+quizQuestionId,
  success: function(msg){ 
    initializeQuizQuestions();
    setPublishButtonStatus();
  }
});  



//delete action - fails in ie
  function deleteQuizQuestion(quizQuestionId, quizId){
    //send ajax call to back end to change the difficulty of the quiz question
    //back end will then refresh the relevant parts of the page (progress bars, flashes, quiz status)
    jQuery.ajax({
      async:true, 
      dataType:'script', 
      type:'delete', 
      url:"/quizzes/"+quizId+"/quiz_questions/"+quizQuestionId,
      success: function(msg){ 
        alert("success");
        initializeQuizQuestions();
        setSelectStatus(quizQuestionId, true);
        jQuery("tr[id*='quiz_question_"+quizQuestionId+"']").removeClass('selected');        
      },
      error: function(msg){
        alert("error:" + msg);
      }
    });     
  }

我在删除 ajax 中设置了成功和错误警报只是为了看看会发生什么,并且触发了 ajax 调用的“错误”部分,但没有调用后端(我通过观察我的后端知道这一点)服务器日志)。因此,它甚至在发出呼叫之前就失败了。我不知道为什么 - 我从错误块中返回的“味精”是空白的。

任何人的想法?这是一个已知问题吗?我已经在 ie6 和 ie8 中测试过它,但它在两者中都不起作用。

谢谢 - 最大

编辑 - 解决方案 - 感谢 Nick Craver 为我指明了正确的方向。

Rails(也许还有其他框架?)对不受支持的 put 和 delete 请求有一个诡计:参数“_method”(注意下划线)设置为“put”或“delete”的 post 请求将被视为实际请求类型是那个字符串。因此,就我而言,我进行了此更改 - 请注意“数据”选项:

   jQuery.ajax({
      async:true, 
      data: {"_method":"delete"},
      dataType:'script', 
      type:'post', 
      url:"/quizzes/"+quizId+"/quiz_questions/"+quizQuestionId,
      success: function(msg){ 
        alert("success");
        initializeQuizQuestions();
        setSelectStatus(quizQuestionId, true);
        jQuery("tr[id*='quiz_question_"+quizQuestionId+"']").removeClass('selected');        
      },
      error: function(msg){
        alert("error:" + msg);
      }
    });     
  }

Rails 现在会将其视为删除请求,从而保留 REST 系统。我的 PUT 示例工作的原因只是因为在这种特殊情况下 IE 很乐意发送 PUT 请求,但它正式不支持它们,因此最好对 PUT 请求和 DELETE 请求执行此操作。

2个回答

IE 7 和 8 不支持 DELETE 和 PUT 方法。我遇到了一个问题,IE7,8 不会遵循 302 重定向,并且 IE 会使用 DELETE 或 PUT 方法来定位它应该重定向到的位置(使用 get。)

为了确保 IE7 和 8 正常工作,我将使用带有参数的 POST:

data: {'_method': 'delete'}

看看你的 type 属性 type:'delete'

关于类型的 jQuery 文档

要发出的请求类型(“POST”或“GET”),默认为“GET”。注意:这里也可以使用其他的 HTTP 请求方法,如 PUT 和 DELETE,但并非所有浏览器都支持。

我会尝试将其包含在您的数据中并在服务器端查找它,如下所示:

data: {'action': 'delete'},
@Max - 只是为了踢球,试着type:'DELETE'看看会发生什么。是的 jitter 刚刚找到旧的测试笔记,IE6 已出局 IE7 可能支持大写。
2021-04-23 13:30:27
@jitter - 它不在此处,仅在 IE8 中进行了测试,但在其他所有浏览器中也同样有效,试图找到列出了已测试浏览器的 jQuery 开发说明……曾经有一个完整的列表。
2021-05-03 13:30:27
啊。胡说。谢谢尼克。我想重新思考是有必要的,这意味着打破我可爱的宁静模式。:( grrrr. 其他人知道任何神奇的方法来解决这个问题吗?
2021-05-10 13:30:27
检查修改后的评论。如果我没记错的话,IE 没有像它应该的那样将所有方法的 XHR 中的类型大写
2021-05-15 13:30:27
嗯,您甚至确认 IE 不支持删除作为 http 请求方法吗?AFAIK IE XHR 对象也支持删除。但您可能需要更改type:'delete'type:'DELETE'
2021-05-18 13:30:27