ASP.NET MVC View向Controller提交数据
我们知道使用MVC的一个很重的的用途就是把Controller和View之间进行解耦,通过控制器来调用不同的视图,这就注定了Controller和View之间的传值是一个很重的知识点,这篇博文主要解释一下View向Controller提交数据的几种形式,认识有限,有不足的地方请各位博友能够给完善。
一、通过Json数据
方法一:使用$.getJSON
- //方式一:根据页码 异步请求 数据
- function loadPageList(pageIndex) {
- $.getJSON("/Stu/List/" + pageIndex, null, function (jsonData) {
- if (jsonData.Statu == "ok") {
- $("#tbList tr:gt(0)").remove();
- $("#trTemp").tmpl(jsonData.Data.PagedData).appendTo("#tbList");
- //生成页码条
- makePageBar(loadPageList, document.getElementById("pageBar"), jsonData.Data.PageIndex, jsonData.Data.PageCount, 2, jsonData.Data.RowCount);
- }
- });
- }
方法二:使用$.get
- //方式二:根据页码 异步请求 数据
- function loadPageList(pageIndex) {
- $.get("/Stu/List/" + pageIndex, null, function (jsonData) {
- if (jsonData.Statu == "ok") {
- $("#tbList tr:gt(0)").remove();
- $("#trTemp").tmpl(jsonData.Data.PagedData).appendTo("#tbList");
- //生成页码条
- makePageBar(loadPageList, document.getElementById("pageBar"), jsonData.Data.PageIndex, jsonData.Data.PageCount, 2, jsonData.Data.RowCount);
- }
- }, "json");
- }
上面这两种方式的到的结果是没有区别的,如果使用$.getJSON,相当于直接指明传递的数据为Json格式;如果使用$.get,则需要在最后加上参数类型"json"即可。
二、通过From表单
方法一:使用Ajax.BeginForm
- <!-------------- 添加对话框--开始----------------------------------------->
- <div id="addDiv">
- @using (Ajax.BeginForm("Add", new AjaxOptions() { OnSuccess = "afterAdd" }))
- {
- <table>
- <tr>
- <td>系列名称:</td>
- <td>
- @Html.TextBox("SerialName")
- </td>
- </tr>
- </table>
- }
- </div>
其中,"Add"是该表单要提交到的Action的名字,OnSuccess="afterAdd"是该表单提交后要执行的js事件,然后再js代码中编写让表单提交的命令即可。
- //让表单提交
- $("#addDiv form").submit();
方法二:使用<form></form>
- <!--导入Word-->
- <div id="importDiv" style="display: none">
- <form id="ff" action="/NotifyManage/ImportWord" method="post" enctype="multipart/form-data">
- <div style="margin-bottom: 20px">
- <input id="FileUpload" type="file" name="files" data-options="prompt:'请选择一个文件...'" />
- </div>
- </form>
- </div>
然后,使用easyui的jquery提交如下:
- $('#ff').form('submit', {
- url: "/NotifyManage/ImportWord/",
- onSubmit: function () {
- // do some check
- // return false to prevent submit;
- },
- success: function (data) {
- $("#importDiv").dialog("close");
- }
- });
在这里,有一点需要注意的是,easyui中form提交的url是无法传参的,如果你想通过url传参的话,就需要另外一种形式了。
- var fileName = document.getElementById("file").value;
- $('#add').form('submit');
- $.post("/NotifyManage/Add",
- { fileName: fileName },
- function (data) {
- if (data == "ok") {
- //关闭对话框,刷新表
- $("#addDiv").dialog("close");
- //initTable();
- $('#tt').datagrid("reload");
- } else {
- $.messager.alert("提示消息", data);
- }
- });
三、通过String字符串
方法一:提交单个字符串
- function Delete(index) {
- var id = $('#tt').datagrid("getRows")[index].ID;
- $.messager.confirm('确认', '您确定要删除?', function (r) {
- if (r) {
- $.post("/Administrator/Del"+id, function (data) {
- if (data == "ok") {
- //刷新表格,去掉选中状态的 那些行。
- $('#tt').datagrid("reload");
- $('#tt').datagrid("clearSelections");
- } else {
- $.messager.alert("删除失败~~", data);
- }
- });
- }
- });
- }
方法二:提交多个字符串
- //确认设置互评信息按钮事件
- function OK() {
- //①取得权重的值ID
- var weightID = $('#cc').combobox('getValue');
- //②获取评论人ID
- var rows = $('#left').datagrid("getRows");
- var evaluaterIDs = "";
- for (var i = 0; i < rows.length; i++) {
- evaluaterIDs += rows[i].ID + ",";
- }
- evaluaterIDs = evaluaterIDs.substr(0, evaluaterIDs.length - 1);
- //③获取被评论人ID
- var rows = $('#right').datagrid("getRows");
- var criticsIDs = "";
- for (var i = 0; i < rows.length; i++) {
- criticsIDs += rows[i].ID + ",";
- }
- criticsIDs = criticsIDs.substr(0, criticsIDs.length - 1);
- //④提交到后台
- $.post("/SettingEvaluation/SettingEvaluation",
- { wid: weightID, eids: evaluaterIDs, cids: criticsIDs });
- }
提交字符串实际上是根据路由地址中的格式匹配的,提交的格式要和路由中设置的保持一致。
ASP.NET MVC View向Controller提交数据的更多相关文章
- ASP.NET MVC View向Controller传值方式总结
1:QueryString传值1)也可以使用new{}来为form的action增加querystring2)在controler里使用Request.QueryString["word&q ...
- 解析ASP.NET Mvc开发之删除修改数据
目录: 1)从明源动力到创新工场这一路走来 2)解析ASP.NET WebForm和Mvc开发的区别 3)解析ASP.NET Mvc开发之查询数据实例 4)解析ASP.NET Mvc开发之EF延迟加载 ...
- 解析ASP.NET Mvc开发之删除修改数据 分类: ASP.NET 2014-01-04 23:41 3203人阅读 评论(2) 收藏
目录: 从明源动力到创新工场这一路走来 解析ASP.NET WebForm和Mvc开发的区别 解析ASP.NET 和Mvc开发之查询数据实例 解析ASP.NET Mvc开发之EF延迟加载 ------ ...
- 【ASP.NET MVC系列】浅谈数据注解和验证
[ASP.NET MVC系列]浅谈数据注解和验证 [01]浅谈Google Chrome浏览器(理论篇) [02]浅谈Google Chrome浏览器(操作篇)(上) [03]浅谈Google C ...
- [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序读取相关数据
这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译,这里是第七篇:为ASP.NET MVC应用程序 ...
- [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序更新相关数据
这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译,这里是第八篇:为ASP.NET MVC应用程序 ...
- ASP.NET MVC 3.0 Controller基础
ASP.NET MVC 3.0 Controller基础 1.Controller类与方法 Controller(控制器)是ASP.NET MVC的核心,负责处理浏览器请求,并作出响应.Cotro ...
- ASP.Net MVC View
ASP.Net MVC View(视图) View视图职责是向用户提供界面.负责根据提供的模型数据,生成准备提供给用户的格式界面. 支持多种视图引擎(Razor和ASPX视图引擎是官方默认给出的, ...
- ASP.NET MVC应用程序更新相关数据
为ASP.NET MVC应用程序更新相关数据 这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译, ...
随机推荐
- spark-2.0.0与hive-1.2.1整合
SparkSQL与Hive的整合 1. 拷贝$HIVE_HOME/conf/hive-site.xml和hive-log4j.properties到 $SPARK_HOME/conf/ 2. 在$SP ...
- SSLPinning 延伸
AFSecurityPolicy用于验证HTTPS请求的证书,先来看看HTTPS的原理和证书相关的几个问题. HTTPS HTTPS连接建立过程大致是,客户端和服务端建立一个连接,服务端返回一个证书, ...
- Linux服务器建站基础-选择何种配置和安装环境项目
我们准备在搬瓦工笔记中,边整理和分享利用Linux VPS建站过程的同时,也会分享关于用户在选择和使用VPS服务器以及网站管理运营中的一些心得和建议.经常有很多网友在很多主机论坛.QQ群众问道,有没有 ...
- Android View的事件分发
如果接触android开发时间足够长的话,或多或少都会遇到各种各样事件冲突的问题,要想解决这类问题,对深入理解事件分发机制是很有必要的,接下来几天都会尽自己所能尽可能将这方面讲清楚. View的事件 ...
- 1.rs.first()、rs.last()、rs.next()、rs.getRow()
rs.first()获取第一条数据的信息rs.last()获取最后一条数据的信息rs.next()获取下一条数据的信息rs.getRow()获取当前信息的行数 import java.sql.*; p ...
- C#Stopwatch的使用,性能测试
一,先开启开始或继续测量某个时间间隔的运行时间,然后停止,最后重置时间,输出. using System; using System.Collections.Generic; using System ...
- 2016 ASC 移动物联网安全高峰论坛 万物互联时代的安全与隐私
互联网的发展已经迈入了"万物互联"时代.移动设备作为人.物连接的主要入口,让人们享受高效.便利的"互联生活"的同时,也给用户的安全和隐私带来了前所未有的挑战.正 ...
- PHP常用代码大全(新手入门必备)
PHP常用代码大全(新手入门必备),都是一些开发中常用的基础.需要的朋友可以参考下. 1.连接MYSQL数据库代码 <?php $connec=mysql_connect("loc ...
- apt-get dpkg lock 和 debconf 问题
一: 在用sudo apt-get install 安装软件时,由于速度太慢,想换个软件源,直接关闭了终端,apt-get但进程没有结束,结果终端提示 E: Could not get lock /v ...
- Django中使用ModelForm实现Admin功能
接上一篇<Django中使用Bootstrap> ModelForm 可以将数据库中的信息展示在一个表中,因此我们在查询数据库信息时可以使用ModelForm在前端展示查询到的信息. 在上 ...