javascript – 使用Ajax将表单数据发布到控制器方法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 使用Ajax将表单数据发布到控制器方法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1372字,纯文字阅读大概需要2分钟。
内容图文
![javascript – 使用Ajax将表单数据发布到控制器方法](/upload/InfoBanner/zyjiaocheng/727/9c55277e32e743c9b82f688d85c15ac8.jpg)
问题
我想使用AJAX异步地将表单数据发布到控制器.这是我的JavaScript的简化视图:
function SendForm() {
var formData = new FormData();
formData.append('value1', 'hello');
formData.append('value2', 'world');
var xhr = new XMLHttpRequest();
xhr.upload.onload = function() {
// stuff that happens on the callback
};
xhr.open('POST', 'http://server/controller/SomeAction', true);
xhr.setRequestHeader('Content-Type', 'multipart/form-data');
xhr.send(formData);
}
问题始于服务器端,其中所有方法参数均为null.
[HttpPost]
public ContentResult SomeAction(string value1, string value2)
{
if(String.IsNullOrEmpty(value1) || String.IsNullOrEmpty(value2)) { throw new Exception("World not found."); }
return Content("something");
}
问题
我的问题是,为什么所有方法参数都为null?
额外研究
我查看了请求流,我可以从长度上看到那里有内容,但无论出于什么原因,MVC都无法将我在FormData对象中指定的参数与控制器中的methed中的参数相匹配.
我为什么这样做?
是的,我想发布数据.我已经简化了示例,但是我希望发布的数据多于可以放在URL上的数据,因此对于此解决方案,REST方法(在查询字符串上传递数据)是不可接受的.
解决方法:
function SendForm() {
var formData = new FormData();
formData.append('value1', 'hello');
formData.append('value2', 'world');
$.ajax({
url: "http://server/controller/SomeAction",
type: 'post',
cache: false,
contentType: false,
processData: false,
data: formData,
success: function (data) {
// ..... any success code you want
}
});
内容总结
以上是互联网集市为您收集整理的javascript – 使用Ajax将表单数据发布到控制器方法全部内容,希望文章能够帮你解决javascript – 使用Ajax将表单数据发布到控制器方法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。