开发者

asp.net mvc making ajax call JSON

Controller:

   public ActionResult EditOrganizationMeta(int id)
    {

    }


        [HttpPost]
    [ValidateInput(false)]
    public ActionResult EditOrganizationMeta(FormCollection collection)
    {

    }

View:

function DoAjaxCall() {
        var url = '<%= Url.Action("EditOrganizationMeta", "Organization") %>';
        //url = url + '/' + dd;

        $.post(url, null, function(data) {
            alert(data);


        });
    }

  <input type="button" name="something"  value="Save" onclick="DoAjaxCall()" /> 

how would i make the ajax call , i have basically two functions with the same name EditOrganizationMeta,Do the form collection will be passed automatically.Basic confusion 开发者_如何学JAVAis regarding the method call

Ok i made a call by ajax but after that My This code is not running anymore

  [HttpPost]
    [ValidateInput(false)]
    public ActionResult EditOrganizationMeta(FormCollection collection)
    {
        int OrganizationId = 11;
        string OrganizationName = "Ministry of Interior";

        try
        {    
             string ids = Request.Params // **getting error here some sequence is not there** 
            .Cast<string>()
            .Where(p => p.StartsWith("button"))
            .Select(p => p.Substring("button".Length))
            .First();

             String RealValueOfThatControl = collection[ids];


            }

        }
        catch { }


        return RedirectToAction("EditOrganizationMeta", new { id = OrganizationId });

    }

I think that there is no post


You have to pass the data you want through second parameter of $.post call. The easiest way (if you want to post a form) is to use $.serialize like this:

$.post(url, $('#formId').serialize(), function(data) { 
  alert(data); 
});

Where 'formId' is you form identifier. And don't worry about having two methods with same name, they will be distincted by HttpVerb (one will respond only to GET, while second to POST).

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜