在上一篇博客中总结了一下从Controller像View中传值的几种方法。事实上看那些方法和在我们最初学习VB的时候一样,将数据库中的数据显示到前台的页面。数据库还是那个数据库,仅仅是如今前台变成了浏览器。传值的形式发生了变化。从View像Controller中传值有非常多种方法,仅仅简单的说明一下自己使用过的。

使用Form

使用Form提交的方法有非常多种,先结合上次博客中使用Model从Controller向View中传值

一般形式的form

在View中

@*自定义的详细要使用的viewModel*@
@modelTalentServiceCenterFileManage.ViewModel.FileWagesViewModel //将表单使用post的方法提交。调用的是action中缩写的路径方法。这和之前学过的没有区别
<form method="post"action="/FileWages/AddFileWagesInfo">
<tablewidth="84%" border="0" cellpadding="0"cellspacing="0">
<tr>
<td>@Html.TextBoxFor(a => a.kindOfSalaryOld)</td>
//这里的a就是上面自定义的model的类型,这样在textBox中显示的就是对于的kindOfSalaryOld这个属性的值,而这个值是从Controller中传来的
<td>@Html.TextBoxFor(a => a.kindOfSalary)</td>
</tr>
<input type="submit"value="保存" /> //注意这里的控件,当单击时触发post提交方式
</table>

当中form的action中写的是要接受数据的Controller和要使用的当中的方法。当单机submitbutton时,整个表单以post的方式提交。

在Controller中

[HttpPost]//假设有post请求就运行这里的代码

//当中的參数就是从View中传回来的,它的属性值就是用户在文本框中填写的内容
public ActionResultAddFileWagesInfo(FileWagesViewModel addFileWagesEntity)
{
//写详细的用法,就能够直接和后台交互
}

使用BeginForm

在view中

<span style="font-size:14px;"> <div id="import"  padding-top: 10px">
@using (Html.BeginForm("Import", FormMethod.Post, new { id = "fmImport", enctype = "multipart/form-data" }))
{ <input type="text" id="txtModify">
}
</div></span>

当中的“Import”是要调用的方法,“FileWages”是要调用的Controller的名字,FormMethod.Post是form提交的方式。new{}里定义的是HTML的特性设置,能够F12定位有对应的方法解释。

假设要触发表单的提交,能够再js中控制,调用Import方法。

       function Import() {                                                                                                      window.location.href = '@Url.Action("AddFileWagesInfo", "FileWages")?<span style="font-size: 14px; font-family: Arial, Helvetica, sans-serif;">txtModify</span>='+document.getElementById('#txtModify').value;                              }

以上将在text中输入的内容以URL的方式传到Controller中。

使用Ajax

在View中

<span style="font-size:14px;">function UpdateNews()
{
var date = $('#test').datagrid("getChecked");//结合EasyUI,目的是获得选中项
var strKey = [];
$.each(date, function (index, item) {
strKey.push(item.basicInformationNumber//将选中项的basicInformationNumber属性的值加入到定义的数组中
})
console.log(strKey.join(","));//切割数组中的内容
//将他们作为值提交
var Showurl = '/FileWages/ShowInfo?showId='+ strKey;
//使用ajax进行提交
$.ajax({
type: "POST",
dataType: 'json',
url: Showurl,//传递URL的地址
success: function (msg) {
if (msg.success) {
alert("删除成功");
}
else {
alert('删除失败。请联系管理员。',msg.errorMsg);
}
}
});
}
}</span>

在Controller中

<span style="font-size:14px;">public ActionResult DelFileWagesInfo()
{
stringstrSrchKey = Request.QueryString["DelID"].ToString();//这是我们之前非常熟悉的方法
}</span>

小结

事实上自己总结的内容网上都能查到。可是那都是别人的东西,不能由于别人写了自己就不写了。那知识永远都不会是你自己的。今天开师徒会说道这样一种情况:遇到一个问题。自己记得非常清楚原来解决过,然后就開始找自己原来的笔记、博客,非常无奈的是发现自己没有做记录,然后由開始从网上找资料,这样效率比較低,并且由于没有总结所以自己脑子里是没有深刻印象的。当又一次遇到的时候仅仅能在查。

所以总结一定要时时的做。不要小瞧当初解决那个问题的办法有多简单。让它变成自己的!

MVC 从View像Controller中传值的更多相关文章

  1. 【ASP.NET MVC】View与Controller之间传递数据

    1   概述 本篇文章主要从操作上简要分析Controller<=>View之间相互传值,关于页面之间传值,如果感兴趣,可参考我另外一篇文章ASP.NET 页面之间传值的几种方式 . Co ...

  2. ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能

    参考:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/examining-the-edit-method ...

  3. MVC中view和controller相互传值的方法

    MVC项目中,在view层如果使用前台框架,框架中会有封装好的相互传值方法.但是,那些postdata[][]方法不一定能够满足功能需求,反而一些常用的传值方法可能会刚好解决它们的不足.总结如下: 一 ...

  4. ASP.NET MVC 前端(View)向后端(Controller)中传值

    在MVC中,要把前端View中的值传递给后端Controller, 主要有两种方法 1. 利用Request.Form 或者 Request.QueryString public ActionResu ...

  5. ASP.NET MVC 学习8、Controller中的Detail和Delete方法

    参考:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/examining-the-details-and ...

  6. Asp.Net MVC part2 View、Controller详解

    View详解Razor视图引擎简介HtmlHelper强类型页面 Razor视图引擎简介强大的@:表示使用C#代码,相当于aspx中的<%%>可以完成输出功能当遇到html标签时会认为C# ...

  7. 【MVC架构】——怎样利用Json在View和Controller之间传递数据

    在MVC架构中,尽管非常多东西和三层非常相似,可是也有非常大的差别.就比方传递数据.在三层架构中,传递数据就仅仅要一层返回,另外一层用同样类型的变量来接收即可了.在MVC中,事实上原理是一样的,Con ...

  8. MVC架构在Asp.net中的应用和实现

    转载自:http://www.cnblogs.com/baiye7223725/archive/2007/06/07/775390.aspx 摘要:本文主要论述了MVC架构的原理.优缺点以及MVC所能 ...

  9. 【MVC框架】——View和Controller之间的传值

    在MVC中,Controller运行一个能够说是路由功能.它通过View传过来的数据,来决定应该调用哪一个Model,相同会把Model处理完的数据传给View,所以就总是涉及到Controller和 ...

随机推荐

  1. 【iOS开发系列】XIB IBOutlets use strong or weak ?

    有人问.在ARC下,IBOutlets究竟应该定义成strong 还是 weak ?支持这个答案的人最多.答案仅是摘自官方文档的一个片段: From a practical perspective, ...

  2. 派生类地址比基类地址少4(CDerived对象的起始地址存放的是虚表指针vptr,也就是子类的第一项内容。接下来的是基类的成员变量,接下来再是自身的成员变量)

    大家对虚表并不陌生,都知道每个含有虚函数的类对象都有1个虚指针,但是在现实使用中,却总是因为这而调试半天,才发现原来是虚指针惹的祸.我这几天在调试代码时候也中招了,我的问题是这样的,如下图,CTree ...

  3. js 回调函数小例子

    js 回调函数小例子 <script> //将函数作为另一个函数的参数 function test1(){ alert("我是test1"); } function t ...

  4. Python·Jupyter Notebook各种使用方法记录

    标签(空格分隔): Python 一 Jupyter NoteBook的安装 1 新版本Anaconda自带Jupyter 2 老版本Anacodna需自己安装Jupyter 二 更改Jupyter ...

  5. Spark Streaming概念学习系列之Spark Streaming的竞争对手

    不多说,直接上干货! Spark Streaming的竞争对手 Storm 在Storm中,先要设计一个用于实时计算的图状结构,我们称之为拓扑(topology).这个拓扑将会被提交给集群,由集群中的 ...

  6. Python 对象初识

    # Demo1class Penson: animal = 'big mom' plant = 'flower' def __init__(self,name,age,sex,job): self.n ...

  7. VSCode新建vue文件自定义模板

    在一个Vue的项目中,反复的新建.vue文件是一个必不可少的工序.本着科技让人偷懒的原则,我们可以利用VSCode的snippet在.vue文件创建后能轻松地生成一套模板. 整个过程是轻松加愉快的,只 ...

  8. iOS11中navigationBar上 按钮图片设置frame无效 不受约束 产生错位问题 解决

    问题描述: 正常样式: 在iOS 11 iPhone X上显示效果: 观察顶部navBar上的左侧按钮  在ios 11 上  这个按钮的图片不受设置的尺寸约束,按其真实大小展示,造成图片错位,影响界 ...

  9. C/C++中的函数指针

    C/C++中的函数指针 一.引子 今天无聊刷了leetcode上的一道题,如下: Median is the middle value in an ordered integer list. If t ...

  10. ZBrush中Flatten展平笔刷介绍

    本文我们来介绍ZBrush®中的Flatten展平笔刷,Flatten笔刷能增加粗糙的平面在模型表面,利用它能够制作出完全的平面. Flatten展平笔刷 Flatten(展平):Flatten笔刷可 ...