ASP.NET MVC視圖頁使用jQuery傳遞異步數(shù)據(jù)的幾種方式詳解
在ASP.NET MVC的視圖頁向控制器傳遞異步數(shù)據(jù),可能是數(shù)組,JavaScript對(duì)象,json,表單數(shù)據(jù),等等。
關(guān)于數(shù)據(jù),JavaScript對(duì)象有時(shí)候和json長得一模一樣,有么有?
var person = {Name: 'darren', Age: 21};
以上是一個(gè)JavaScript對(duì)象。不過也可以這樣表示:
var person = {"Name":"darren","Age":21};
以上JavaScript對(duì)象的另外一種表達(dá)方式,恰恰也符合json的表達(dá)方式。不過,JavaScript對(duì)象的寫法推薦使用第一種方式。
關(guān)于異步ajax發(fā)送;data屬性表示傳遞的數(shù)據(jù);contentType樹形的默認(rèn)值是application/x-www-form-urlencoded,表示客戶端請(qǐng)求類型;dataType表示從服務(wù)端返回的類型,可以是text, xml, json, script, html, jsonp。
而在服務(wù)端,通過Request.Form屬性可以獲得從客戶端傳遞來的異步數(shù)據(jù)。
傳遞JavaScript對(duì)象
在Home/Index.cshtml視圖中,使用jQuery發(fā)出一個(gè)異步請(qǐng)求,把返回的html內(nèi)容加載到當(dāng)前視圖中。
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>Index</h2>
<div id="result"></div>
@section scripts
{
<script type="text/javascript">
$(function() {
var person = {Name: 'Darren', Age: 21};
$.ajax({
type: 'GET',
url: '@Url.Action("GetInfo","Home")',
data: person,
datatype: 'html',
success:function(data) {
$('#result').html(data);
}
});
});
</script>
}HomeController中從Request.Form中獲取數(shù)據(jù),并返回強(qiáng)類型部分視圖。
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult GetInfo()
{
//從表單中獲取的數(shù)據(jù)
var person = new Person();
person.Name = Request["Name"];
person.Age = int.Parse(Request["Age"]);
return PartialView("_DisplayJavaScriptObject", person);
}
}Home/_DisplayJavaScriptObject.cshtml強(qiáng)類型視圖展示數(shù)據(jù)。
@model MvcApplication1.Models.Person
<div>
<h3>從表單中讀出的數(shù)據(jù)</h3>
<p><span>Name:</span><span>@Model.Name</span></p>
<p><span>Age:</span><span>@Model.Age</span></p>
</div>傳遞數(shù)組
傳遞數(shù)組的時(shí)候有幾點(diǎn)需注意:
1、需要把數(shù)組toString()后作為json數(shù)據(jù)傳遞,toString()后數(shù)組變成以逗號(hào)隔開的字符串
2、是以Query String的形式傳遞給服務(wù)端的
3、服務(wù)端為了獲取集合數(shù)據(jù),需要split數(shù)組字符串
在Home/Index.cshtml視圖中,使用jQuery發(fā)送異步GET請(qǐng)求時(shí),數(shù)組ids需要toString()轉(zhuǎn)換成"1,2,3"形式的字符串。
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>Index</h2>
<div id="result"></div>
@section scripts
{
<script type="text/javascript">
$(function() {
var ids = [1, 2, 3];
$.ajax({
type: 'GET',
url: '@Url.Action("GetInfo","Home")',
data: { myArr: ids.toString() },
datatype: 'html',
success:function(data) {
$('#result').html(data);
}
});
});
</script>
}在HomeController中,通過Request.QueryString來獲取數(shù)組字符串,最后再split轉(zhuǎn)換成集合。
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult GetInfo()
{
string temp = Request.QueryString["myArr"];
List<int> result = new List<int>();
string[] tempArr = temp.Split(',');
foreach (var item in tempArr)
{
result.Add(int.Parse(item));
}
ViewData["t"] = result;
return PartialView("_DisplayJavaScriptObject");
}
}Home/_DisplayJavaScriptObject.cshtml從ViewData中取出數(shù)據(jù)遍歷集合展示數(shù)據(jù)。
@foreach (var item in ViewData["t"] as IEnumerable<int>)
{
<span>@item.ToString()</span>
}傳遞表單數(shù)據(jù)
傳遞表單數(shù)據(jù)的時(shí)候有幾點(diǎn)需注意:
1、通過$('#myForm').serialize()把表單數(shù)據(jù)封裝起來
2、控制器Action方法需要打上[HttpPost]
3、控制器Action方法,可以通過強(qiáng)類型參數(shù)來接收,也可通過Request["Name"]的方式獲取數(shù)據(jù)
在Home/Index.cshtml視圖中,使用jQuery發(fā)送異步POST請(qǐng)求時(shí),使用$('#myForm').serialize()把表單數(shù)據(jù)封裝起來。
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>Index</h2>
<div>
<form id="myForm">
<div>
@Html.Label("Name","姓名")
@Html.TextBox("Name","Darren")
</div>
<div>
@Html.Label("Age","年齡")
@Html.TextBox("Age","21")
</div>
</form>
<div>
<button id="btn">提交</button>
</div>
</div>
<div id="result"></div>
@section scripts
{
<script type="text/javascript">
$(function() {
$('#btn').on("click", function() {
$.ajax({
type: 'POST',
url: '@Url.Action("GetInfo","Home")',
data: $('#myForm').serialize(),
dataType: 'html',
success: function(data) {
$('#result').html(data);
}
});
});
});
</script>
}在HomeController中,需要在GetInfo方法上打上[HttpPost],用強(qiáng)類型參數(shù)來接收數(shù)據(jù)。
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
[HttpPost]
public ActionResult GetInfo(Person person)
{
return PartialView("_DisplayJavaScriptObject", person);
}
}Home/_DisplayJavaScriptObject.cshtml強(qiáng)類型視圖展示數(shù)據(jù)。
@model MvcApplication1.Models.Person
<div>
<h3>從表單中讀出的數(shù)據(jù)</h3>
<p><span>Name:</span><span>@Model.Name</span></p>
<p><span>Age:</span><span>@Model.Age</span></p>
</div>傳遞json數(shù)據(jù)
傳遞json數(shù)據(jù)需注意的是:
1、json格式要寫對(duì):{ "Name":"Darren","Age":21}
2、控制器Action方法中通過Request["Name"]的方式獲取數(shù)據(jù)
在Home/Index.cshtml視圖中,使用jQuery發(fā)送異步Get請(qǐng)求。
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>Index</h2>
<div id="result"></div>
@section scripts
{
<script type="text/javascript">
$(function() {
$.ajax({
type: 'GET',
url: '@Url.Action("GetInfo","Home")',
data: { "Name":"Darren","Age":21},
datatype: 'html',
success:function(data) {
$('#result').html(data);
}
});
});
</script>
}在HomeController中通過Request["Name"]的方式獲取數(shù)據(jù)。
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult GetInfo()
{
//從表單中獲取的數(shù)據(jù)
var person = new Person();
person.Name = Request["Name"];
person.Age = int.Parse(Request["Age"]);
return PartialView("_DisplayJavaScriptObject", person);
}
}Home/_DisplayJavaScriptObject.cshtml強(qiáng)類型視圖展示數(shù)據(jù)。
@model MvcApplication1.Models.Person
<div>
<h3>從表單中讀出的數(shù)據(jù)</h3>
<p><span>Name:</span><span>@Model.Name</span></p>
<p><span>Age:</span><span>@Model.Age</span></p>
</div>以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- ASP.NET?MVC通過勾選checkbox更改select的內(nèi)容
- ASP.NET?MVC使用Log4Net記錄異常日志并跳轉(zhuǎn)到靜態(tài)頁
- ASP.NET?MVC實(shí)現(xiàn)樹形導(dǎo)航菜單
- ASP.NET?MVC擴(kuò)展帶驗(yàn)證的單選按鈕
- ASP.NET MVC實(shí)現(xiàn)橫向展示購物車
- ASP.NET MVC獲取多級(jí)類別組合下的產(chǎn)品
- ASP.NET MVC使用正則表達(dá)式驗(yàn)證手機(jī)號(hào)碼
- ASP.NET?MVC實(shí)現(xiàn)登錄后跳轉(zhuǎn)到原界面
- ASP.NET?MVC使用jQuery的Load方法加載靜態(tài)頁面及注意事項(xiàng)
相關(guān)文章
ASP.NET MVC從控制器傳遞數(shù)據(jù)到視圖的四種方式詳解
本篇文章主要介紹了ASP.NET MVC從控制器傳遞數(shù)據(jù)到視圖的四種方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-01-01
關(guān)于HttpHandler與HttpModule的理解和應(yīng)用方法
本篇文章小編將為大家介紹,關(guān)于HttpHandler與HttpModule的理解和應(yīng)用方法,有需要的朋友可以參考一下2013-04-04
.NET使用js制作百度搜索下拉提示效果(不是局部刷新)實(shí)現(xiàn)思路
搞了個(gè)不是局部刷新的百度搜索框下拉提示效果大致思路:前臺(tái)放一個(gè)input標(biāo)簽,然后當(dāng)該標(biāo)簽內(nèi)的值輸入有變化的時(shí)候,調(diào)用后臺(tái)代碼查詢 符合條件的數(shù)據(jù)綁定ListBox,感興趣的朋友可以了解下2013-01-01
完美兼容ie和firefox的asp.net網(wǎng)站加入收藏和設(shè)置主頁
這篇文章主要介紹了完美兼容ie和firefox的asp.net網(wǎng)站加入收藏和設(shè)置主頁,需要的朋友可以參考下2014-12-12
.NET下文本相似度算法余弦定理和SimHash淺析及應(yīng)用實(shí)例分析
這篇文章主要介紹了.NET下文本相似度算法余弦定理和SimHash淺析及應(yīng)用,實(shí)例形式詳細(xì)講述了相似度算法余弦定理和SimHash的原理與用法,需要的朋友可以參考下2015-01-01

