首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用ajax调用将表单集合传递给操作?

如何使用ajax调用将表单集合传递给操作?
EN

Stack Overflow用户
提问于 2013-07-23 04:43:33
回答 3查看 34.7K关注 0票数 16

我正在尝试用ajax调用替换表单提交。操作需要want集合,而我不想创建新的Model。所以我需要传递整个表单(就像表单提交一样),但是要通过ajax调用。我试图序列化并使用Json,但是formcollection是空的。这是我的动作签名:

代码语言:javascript
运行
复制
public ActionResult CompleteRegisteration(FormCollection formCollection)

这是我的提交按钮点击:

代码语言:javascript
运行
复制
var form = $("#onlineform").serialize();              
            $.ajax({
                url: "/Register/CompleteRegisteration",                
                datatype: 'json',
                data: JSON.stringify(form),
                contentType: "application/json; charset=utf-8",                
                success: function (data) {
                    if (data.result == "Error") {
                        alert(data.message);
                    }
                }
            });

现在,我如何将数据传递到formcollection?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-07-23 04:57:59

因为FormCollection是许多键-值对,所以不适合用它来表示。您应该只使用序列化的表单字符串:

代码语言:javascript
运行
复制
var form = $("#onlineform").serialize();
$.ajax({
    type: 'POST',
    url: "/Register/CompleteRegisteration",
    data: form,
    dataType: 'json',
    success: function (data) {
        if (data.result == "Error") {
            alert(data.message);
        }
    }
});

主要变化:

设置为POST的请求的

  1. type (这里不是必需的,但似乎更多的是natural)
  2. Serialized形式而不是JSON字符串,因为删除了请求data
  3. contentType -我们不再发送JSON
票数 38
EN

Stack Overflow用户

发布于 2013-07-23 04:54:41

尝试:

代码语言:javascript
运行
复制
$(<your form>).on('submit',function(){
    $.ajax({
        url: "/Register/CompleteRegisteration" + $(this).serialize(), 
        // place the serialized inputs in the ajax call                
        datatype: 'json',
        contentType: "application/json; charset=utf-8",                
        success: function (data) {
            if (data.result == "Error") {
                alert(data.message);
            }
        }
    });
});
票数 5
EN

Stack Overflow用户

发布于 2016-03-30 18:39:30

如果有人想要向FormCollection传递额外的数据,您可以尝试下面的方法。

代码语言:javascript
运行
复制
<script type="text/javascript"> 
function SubmitInfo() 
{
    var id = $("#txtid").val();    
    var formData = $('#yourformname').serializeObject();
    $.extend(formData, { 'User': id }); //Send Additional data

    $.ajax({
        url: 'Controlle/GetUser',
        cache: false,
        type: 'POST',
        dataType: 'json',
        data: decodeURIComponent($.param(formData)),
        success: function (data) {
            $('#resultarea').html(data);
        },
        error: function (jqXHR, textStatus, errorThrown) {
            alert("AJAX error: " + textStatus + ' : ' + errorThrown);
        }
    });
}

$.fn.serializeObject = function () {
    var o = {};
    var a = this.serializeArray();
    $.each(a, function () {
        if (o[this.name] !== undefined) {
            if (!o[this.name].push) {
                o[this.name] = [o[this.name]];
            }
            o[this.name].push(this.value || '');
        } else {
            o[this.name] = this.value || '';
        }
    });
    return o;
};
<script/>

动作方法

代码语言:javascript
运行
复制
public ActionResult GetUser(FormCollection frm)
  {
   int UserId = Convert.ToInt32(frm["user"]);
   // your code
   return Json(data, JsonRequestBehavior.AllowGet);
  }

Refer link获取更多详细信息。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17797053

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档