WebAPI Ajax用法

使用WebAPI:在Visual Studio 2012中新建MVC4项目,在App_Start目录下有一个WebApiConfig.cs文件,这个文件中就是相应的Web API的路由配置了。

 

先创建了一个UserModel

 

public class UserModel
{
    public string UserID { get; set; }
    public string UserName { get; set; }
}

 

然后添加Web API Controller

 

public class UserController : ApiController
{
    public UserModel getAdmin()
    {
        return new UserModel() { UserID = "000", UserName = "Admin" };
    } 
}

 

注册路由

 

public static void Register(HttpConfiguration config)
{
    config.Routes.MapHttpRoute(
        name: "DefaultApi",
        routeTemplate: "api/{controller}/{id}",
        defaults: new { id = RouteParameter.Optional }
    );
}

 

在Global中注册

 

protected void Application_Start(object sender, EventArgs e)
{
    WebApiConfig.Register(GlobalConfiguration.Configuration);
}

 

这个时候用地址栏访问地址:api/user/getadmin

 

image

 

这个时侯默认返回的是XML数据模型。

 

使用AJAX请求这个api,指定数据格式为json

 

$.ajax({
    type: 'GET',
    url: 'api/user/getadmin',
    dataType: 'json',
    success: function (data, textStatus) {
        alert(data.UserID + " | " + data.UserName);
    },
    error: function (xmlHttpRequest, textStatus, errorThrown) {
    }
});

 

alert出来的结果是:

 

image

 

这样看来,真的是dudu所说的,可以根据请求的数据类型返回指定的数据格式。

 

 

 

POST数据

 

修改一下controller,添加一个add方法

 

public bool add(UserModel user)
{
    return user != null;
}

 

只为了测试,所以这里只判断一下传入的实体是否为空,如果不为空则返回true

 

我在页面上添加了一个button,代码如下:

 

<input type="button" name="btnOK" id="btnOK" value="发送POST请求" />

 

添加JS代码

 

$('#btnOK').bind('click', function () {
    //创建ajax请求,将数据发送到后台处理
    var postData = {
        UserID: '001',
        UserName: 'QeeFee'
    };
    $.ajax({
        type: 'POST',
        url: 'api/user/add',
        data: postData,
        dataType: 'json',
        success: function (data, textStatus) {
            alert(data);
        },
        error: function (xmlHttpRequest, textStatus, errorThrown) {
        }
    });
});

 

再次运行页面

 

image

 

我们附加进程进行调试,在发送ajax请求的时候,服务器段接收到的数据如图:

 

image

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值