我目前正在为 WebAPI 进行 Pluralsight 培训,并且遇到了一些问题(下载示例并没有帮助,因为它们也不起作用 - 该课程是从 Beta 版创建的,我正在使用 .Net 的最终版本4.5)。我使用以下 HTML 创建了一个非常简单的视图:
<form onsubmit="return submitCourse();">
<input type="text" name="name" id="name" />
<input type="submit" value="Create Course" />
</form>
<h1 id="msg"></h1>
<script>
//1: have form - get values from form - send to API as json
//2: use form values
function submitCourse() {
//$.ajax({
// url: '/api/courses',
// type: 'POST',
// dataType: 'json'
//});
$.ajax({
url: '/api/courses/',
type: 'POST',
dataType: 'json',
success: function (newCourse) {
var msg = 'New course id = ' + newCourse.id;
$('#msg').text(msg);
}
});
return false;
}
</script>
应该发生的是当表单提交时,脚本首先运行,表单数据通过 AJAX 调用为我传输。我遇到的问题是当 Post 方法在我的控制器中被击中时,“newCourse”参数始终为空:
public Course Post(Course newCourse)
{
newCourse.id = _courses.Count;
_courses.Add(newCourse);
//TODO : return 201
return newCourse;
}
通过各种工具挖掘,我发现上面的脚本似乎根本没有发送数据(内容长度为 0),但我似乎无法弄清楚为什么(WebAPI 和 jQuery 的 $.ajax() 调用的新手)。我尝试使用 $.ajax() 调用中的“data”选项将调用的主体显式设置为表单值(如下所示:data: { 'name' : $('#name').text( ) } ),但这也没有多大作用。内容长度似乎发生了变化(变为 5,不知道为什么),但这些值仍然没有被反序列化。
有小费吗?我对这两种技术都太陌生了,不知道从哪里开始。