我的DropDownListFor看起来像:
@Html.DropDownListFor(
m => m.CampaignID,
new SelectList(Model.Campaigns, "ID", "Name"),
"---Geen---",
new {
id = "campaignDdl",
data_url = Url.Action("CampaignChosen", "Nomination")
}
)
我的onchange javascript看起来像:
$(function () {
$('#campaignDdl').change(function () {
//alert('Template knop geklikt');
var $campaignDdl = $('#campaignDdl');
var selCampID = $campaignDdl.val();
var url = $campaignDdl.data('url');
$.post(url, { selectedCampaignID: selCampID }, function (data) {
$('#campaign').html(data);
})
.fail(function (jqxhr) { alert(JSON.stringify(jqxhr)); });
});
});
我的CampaignChosen操作如下:
[AcceptVerbs("POST")]
public ActionResult CampaignChosen(string selectedCampaignID) {
if (!string.IsNullOrEmpty(selectedCampaignID)) {
int campaignID = Convert.ToInt32(selectedCampaignID);
Models.Campaign campaign = Models.Campaign.GetCampaignByID(campaignID);
return PartialView("ShowCampaignOverview", campaign);
} else {
return PartialView("ShowCampaignOverview", null);
}
}
如你所见,我正在通过局部视图。 javascript确保将视图放入带有id =“campaign”的div中。这个div是在你之前看到的下拉列表中定义的,如下所示:
<div id="campaign"></div>
当选择一个项目时,一切正常。不能更快乐。但是当您在浏览器上按下重新加载时,所选项仍会显示在下拉列表中,但我不知道如何再次在该div中加载正确的局部视图。因为我对MVC还有点新意。
有人能指出这通常是如何在MVC中完成的吗?提前感谢您的回答。
答案 0 :(得分:1)
你可以模仿jquery.ready函数的onchange函数:
$(document).ready(function() {
//alert('Template knop geklikt');
var $campaignDdl = $('#campaignDdl');
var selCampID = $campaignDdl.val();
var url = $campaignDdl.data('url');
$.post(url, { selectedCampaignID: selCampID }, function (data) {
$('#campaign').html(data);
})
});
这应该与ddl更改时完全相同,而是采用已经选择的值并将相应的视图放在div中。
答案 1 :(得分:1)
您也可以调用更改方法,以便不重复代码,如下所示:
$(function () {
$('#campaignDdl').change(function () {
//alert('Template knop geklikt');
var $campaignDdl = $('#campaignDdl');
var selCampID = $campaignDdl.val();
var url = $campaignDdl.data('url');
$.post(url, { selectedCampaignID: selCampID }, function (data) {
$('#campaign').html(data);
});
})
.fail(function (jqxhr) {
alert(JSON.stringify(jqxhr));
})
.change();
});
答案 2 :(得分:1)
试试这个,
$(document).ready(function() {
//alert('Template knop geklikt');
var $campaignDdl = $('#campaignDdl');
var selCampID = $campaignDdl.val();
var url = $campaignDdl.data('url');
$.post(url, { selectedCampaignID: selCampID }, function (data) {
$('#campaign').html('');
$('#campaign').append(data.Data);
})
})
答案 3 :(得分:1)
我建议您使用$.load()代替$ .post() 关于将新的加载代码块放入函数中并在页面加载时调用onece,并在事件被调整时调用一次。
$(document).ready(function() {
$('#campaignDdl').change(function () {
loadCampaignById();
.fail(function (jqxhr) { alert(JSON.stringify(jqxhr)); });
});
loadCampaignById();
});
function loadCampaignById()
{
var $campaignDdl = $('#campaignDdl');
var selCampID = $campaignDdl.val();
var url = $campaignDdl.data('url');
$('#campaign').load(url + "/" + selCampID));
})