在将jQuery更新到1.9.0后,不显眼的Ajax停止工作

时间:2013-01-18 03:14:26

标签: jquery asp.net-mvc-3 unobtrusive-ajax

我刚刚更新了jQuery& jQuery UI: jquery-1.9.0.min.js和 的jquery-UI-1.9.2.min.js

并且......我所有不引人注意的Ajax调用(Ajax.ActionLink,Ajax.BeginForm)都停止正常工作 - 它们在新页面中打开结果,而不是更新现有的div。

当我的页面加载时,我在Firebug中收到此javascript错误:

enter image description here

代码当然没有改变,只是使用Nuget更新了jQuery脚本。

任何人都遇到过同样的问题吗?

8 个答案:

答案 0 :(得分:69)

更新:此问题已在最新的NuGet程序包中修复。我发布了另一个答案来反映这一点。 https://stackoverflow.com/a/15539422/714309


jquery.unobtrusive-ajax.js中,找到并替换这四行:

  1. $("a[data-ajax=true]").live("click", function (evt) {

    $(document).on("click", "a[data-ajax=true]", function (evt) {

  2. $("form[data-ajax=true] input[type=image]").live("click", function (evt) {

    $(document).on("click", "form[data-ajax=true] input[type=image]", function (evt) {

  3. $("form[data-ajax=true] :submit").live("click", function (evt) {

    $(document).on("click", "form[data-ajax=true] :submit", function (evt) {

  4. $("form[data-ajax=true]").live("submit", function (evt) {

    $(document).on("submit", "form[data-ajax=true]", function (evt) {

  5. 您还可以使用WebGrease生成新的jquery.unobtrusive-ajax.min.js。 从命令提示符,切换到您的解决方案文件夹并输入此命令(假设您的项目文件夹名为Web):

    packages\WebGrease.1.3.0\tools\WG.exe -m -in:Web\Scripts\jquery.unobtrusive-ajax.js -out:Web\Scripts\jquery.unobtrusive-ajax.min.js
    

答案 1 :(得分:42)

Microsoft jQuery Unobtrusive Ajax NuGet包更新为最新版本。

在Visual Studio中,从工具菜单中选择库包管理器,然后单击包管理器控制台。在提示符下键入:

Update-Package Microsoft.jQuery.Unobtrusive.Ajax

此问题已在Microsoft jQuery Unobtrusive Ajax 2.0.30116.0(2013年2月18日,星期一)中修复,该方法取代了对.live()方法(在jQuery 1.7和removed from jQuery 1.9中弃用)的调用推荐的.on()方法。

答案 2 :(得分:28)

.live()自1.7以来已被弃用,正式为removed in jQuery 1.9。请改用.on(),因为这是执行same thing的首选方法。

答案 3 :(得分:10)

解决jQuery中重大变化问题的最简单方法(在我看来)是安装jQuery.Migrate包,使您能够使用在1.9.0版本中删除的已弃用函数调用。至少在微软更新不引人注目的ajax插件之前。

此外,似乎不引人注目的ajax插件的每晚构建更新了api调用。我还没有测试过,但你可能会发现如何在asp.net codeplex page中获取它。

更新: Unobtrusive Ajax和Validation Nuget包已更新,因此不再需要jQuery.Migrate包。

答案 4 :(得分:4)

还需要做这些修复:

更新jQuery.Validation插件(to fix this problem

https://nuget.org/packages/jQuery.Validation/1.11.0    (first available on nuget 2/4/13)

同时对jquery.unobtrusive-ajax.js文件(see here for Connect issue

进行这些更改
Line 43: replace = container.attr("data-valmsg-replace") && $.parseJSON(container.attr("data-valmsg-replace")) !== false;

Line 73: replace = container.attr("data-valmsg-replace") && $.parseJSON(container.attr("data-valmsg-replace"));

答案 5 :(得分:3)

替换

.live(function)

使用

.on(eventType, selector, function)

https://stackoverflow.com/a/14354091/358906

答案 6 :(得分:1)

这是一个适合您的实际缩小文件。无论如何都适合我。我只是手动编辑它。

    /*
** Unobtrusive Ajax support library for jQuery
** Copyright (C) Microsoft Corporation. All rights reserved.
*/
(function(a){var b="unobtrusiveAjaxClick",g="unobtrusiveValidation";function c(d,b){var a=window,c=(d||"").split(".");while(a&&c.length)a=a[c.shift()];if(typeof a==="function")return a;b.push(d);return Function.constructor.apply(null,b)}function d(a){return a==="GET"||a==="POST"}function f(b,a){!d(a)&&b.setRequestHeader("X-HTTP-Method-Override",a)}function h(c,b,e){var d;if(e.indexOf("application/x-javascript")!==-1)return;d=(c.getAttribute("data-ajax-mode")||"").toUpperCase();a(c.getAttribute("data-ajax-update")).each(function(f,c){var e;switch(d){case"BEFORE":e=c.firstChild;a("<div />").html(b).contents().each(function(){c.insertBefore(this,e)});break;case"AFTER":a("<div />").html(b).contents().each(function(){c.appendChild(this)});break;default:a(c).html(b)}})}function e(b,e){var j,k,g,i;j=b.getAttribute("data-ajax-confirm");if(j&&!window.confirm(j))return;k=a(b.getAttribute("data-ajax-loading"));i=b.getAttribute("data-ajax-loading-duration")||0;a.extend(e,{type:b.getAttribute("data-ajax-method")||undefined,url:b.getAttribute("data-ajax-url")||undefined,beforeSend:function(d){var a;f(d,g);a=c(b.getAttribute("data-ajax-begin"),["xhr"]).apply(this,arguments);a!==false&&k.show(i);return a},complete:function(){k.hide(i);c(b.getAttribute("data-ajax-complete"),["xhr","status"]).apply(this,arguments)},success:function(a,e,d){h(b,a,d.getResponseHeader("Content-Type")||"text/html");c(b.getAttribute("data-ajax-success"),["data","status","xhr"]).apply(this,arguments)},error:c(b.getAttribute("data-ajax-failure"),["xhr","status","error"])});e.data.push({name:"X-Requested-With",value:"XMLHttpRequest"});g=e.type.toUpperCase();if(!d(g)){e.type="POST";e.data.push({name:"X-HTTP-Method-Override",value:g})}a.ajax(e)}function i(c){var b=a(c).data(g);return!b||!b.validate||b.validate()}a(document).on("click", "a[data-ajax=true]", function(a){a.preventDefault();e(this,{url:this.href,type:"GET",data:[]})});a(document).on("click", "form[data-ajax=true] input[type=image]", function(c){var g=c.target.name,d=a(c.target),f=d.parents("form")[0],e=d.offset();a(f).data(b,[{name:g+".x",value:Math.round(c.pageX-e.left)},{name:g+".y",value:Math.round(c.pageY-e.top)}]);setTimeout(function(){a(f).removeData(b)},0)});a(document).on("click","form[data-ajax=true] :submit", function(c){var e=c.target.name,d=a(c.target).parents("form")[0];a(d).data(b,e?[{name:e,value:c.target.value}]:[]);setTimeout(function(){a(d).removeData(b)},0)});a(document).on("submit","form[data-ajax=true]",function(d){var c=a(this).data(b)||[];d.preventDefault();if(!i(this))return;e(this,{url:this.action,type:this.method||"GET",data:c.concat(a(this).serializeArray())})})})(jQuery);

答案 7 :(得分:0)

只需更新您的脚本

1. 下载最新的Jquery,(我使用了jquery-1.11.0)

2. 从微软官方下载最新的Microsoft.jQuery.Unobtrusive.Ajax

从这里开始:

https://github.com/aspnet/jquery-ajax-unobtrusive

3. :进行硬刷新或清除浏览器缓存并再次检查您的网页。

希望帮助某人。