jquery - 从分部 View 使用 Ajax.BeginForm,表单操作使用父 Controller ,而不是定义的 Controller

标签 jquery ajax asp.net-mvc ajax.beginform

这有点奇怪,因为几周前它还运行良好。这是我所拥有的..

我有一个具有 ajax 表单的部分 View _subscribe

@model m60_mbt.Models.Subscriber

@{bool? subscribed = (bool?)Session["subscribed"];}

@if (subscribed == true)
{
    <div class="subscribe text-center animated fadeInUp">
    <h1>
        Thank you for subscribing to our newsletter.
    </h1>

</div>
}

else
{
<div class="row">       

        <h1><i class="fa fa-paper-plane"></i><span>Subscribe to stay in the loop</span></h1>

        @using (Ajax.BeginForm("Create", "Subscriber", new AjaxOptions
        {
            HttpMethod = "POST",
            InsertionMode = InsertionMode.Replace,
            UpdateTargetId = "subscribe_target"

        }, new { id = "Subscribe" }))
        {
        @Html.AntiForgeryToken()

        @Html.ValidationSummary(true)


            @Html.TextBoxFor(model => model.EmailAddress, new { @placeholder = "Your email address" })

            <input id="sub_but"  type="submit" value="Subscribe" />
            <br />
            @Html.ValidationMessageFor(model => model.EmailAddress)



        }


    </div>
}

它被放置在 View 内。

<section class="subscribe text-center" id="subscribe_target">
    <h1><i class="fa fa-paper-plane"></i><span>Subscribe to stay in the loop</span></h1>
    <div id="subscribe_form">
        @Html.Partial("_subscribe", new m60_mbt.Models.Subscriber());
    </div>
</section>

但是当页面呈现时,表单操作将更改为:

<form action="/Home/Create?Length=10" data-ajax="true" data-ajax-method="POST" data-ajax-mode="replace" data-ajax-update="#subscribe_target" id="Subscribe" method="post">

有什么想法吗?

/* 编辑 */ 这是我的 RouteConfig

public class RouteConfig
{
    public static void RegisterRoutes(RouteCollection routes)
    {
        routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

        routes.MapRoute(
            name: "Default",
            url: "{controller}/{action}/{id}",
            defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
        );
    }
}

最佳答案

您最近似乎添加了 html 属性 new { id = "Subscribe"}。由于这一变化, Controller 被视为路由值。为了使其正常工作,您必须在 Controller 名称和 ajax 设置之间为路由值添加一个参数。因此,如果我将路由值指定为 null,您的代码将如下所示。

@using (Ajax.BeginForm("Create", "Subscriber", null, new AjaxOptions
    {
        HttpMethod = "POST",
        InsertionMode = InsertionMode.Replace,
        UpdateTargetId = "subscribe_target"

    }, new { id = "Subscribe" }))
    {
    @Html.AntiForgeryToken()

    @Html.ValidationSummary(true)


        @Html.TextBoxFor(model => model.EmailAddress, new { @placeholder = "Your email address" })

        <input id="sub_but"  type="submit" value="Subscribe" />
        <br />
        @Html.ValidationMessageFor(model => model.EmailAddress)



    }

关于jquery - 从分部 View 使用 Ajax.BeginForm,表单操作使用父 Controller ,而不是定义的 Controller ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26758499/

相关文章:

javascript - 在客户端添加和删除附件(而不是替换以前的附件)

javascript - 在 iframe 内提交字段

javascript - 输入组将下一个输入推送到下一行

javascript - 从 AJAX 调用 WordPress PHP 函数

javascript - 在 foreach 循环之外调用 javascript 函数

ajax - 参数字典在呈现局部 View 时包含参数错误的空条目

asp.net - 如何正确设置 ASP.NET web.config 以在边缘情况下显示应用程序特定的、安全的和用户友好的 asp.net 错误消息

javascript - 在具有相同js代码的网页上多次使用lightbox

c# - 在 ASP.NET Web 窗体中,如何使用 "get"请求调用页面方法

ajax - MVC Razor Ajax 从按钮点击调用