-2

我需要对返回的 json 到 ajaxform 进行操作。我在 javascript 方面做得不够好......我可以从控制器中的方法返回 Json,但我能正确地做事取决于这个 json 结果吗?

我需要返回状态值,其中状态可以是 1,2 或 2。鉴于我需要实现 JS,它将向 div 添加文本,具体取决于该脚本从方法中获取的 json。一切都应该使用ajax。谁能推荐我好的教程?或者简单地为我编写代码,我将对其进行分析。

4

2 回答 2

1

您可以为 jQuery 编写一个简单的扩展方法:

jQuery.extend({
    postJSON: function (url, data, callback) {
        return jQuery.post(url, data, callback, "json");
    }
});

然后在您的 javascript 块中执行以下操作:

$.postJSON('/controller/action',
{
    Param1: 1, 
    Param2: 2
}, 
function(data){
   alert(data.result);
});

在控制器中

[HttpPost]
public ActionResult Action(int Param1, int Param2)
{
    return Json(new {
       result : "It Worked"
    }); 
}
于 2013-07-25T19:44:42.423 回答
0

这是一个示例,它根据您的操作方法的响应更改分区内的文本...

//a class with properties.  

  Class Priveleges{
Public string StatusMessage{get;set;}
Public int StatusCode{get;set;}
 }


 //code inside controller
  [HttpGet]
  Public JsonResult Index{
  Priveleges obj=DecidePriveleges():
  Return Json(obj,allowget.true);
  }

 Private Priveleges DecidePriveleges(){
  Prilveleges obj;
   //prepare object based on server response
  If(response=="high"){
  obj=new Priveleges(){
  StatusMessage="high priveleges",
  StatusCode=1}
  }else if(response=="medium){
    obj=new Priveleges(){
   StatusMessage="medium priveleges",
   StatusCode=2}
 }else if(response=="low"){
   Obj=new Priveleges(){
   StatusMessage="low priveleges"‚
   StatusCode=3}
  }
  Return obj;



 //code inside ur view
//suppose you want to change the text inside 
//ur div when the page loads..
<div id="statusDiv"></div>

 //here is ur javascript.   
 $(document).ready(function(){
  $.getJSON('/controller/Index',function(data){
  $('#statusDiv').text(
   'You have '+data.StatusMessage);
  });
  });
  //here data,the parameter of getJson method.    
 //holds the data coming from our action
 //method...

抱歉代码格式..从我的手机发布代码...

希望这个小例子可能会有所帮助..

于 2013-07-27T16:47:23.500 回答