[英]Display Partial view in same View mvc4
在我的应用程序中,我已使用div.load()jQuery将局部视图加载到了普通视图中。 我正在尝试更新局部视图中的值,并使用jquery在同一视图中显示局部视图。 是否有其他方法或示例可以实现它。
共同观点
<body>
<div class="block-content" style="width: 200px;">
<ul>
<li><a id="MyAccount" class="common"><strong>Account Dashboard</strong></a></li>
<li><a id="AccountDetails" class="common">Account Information</a></li>
<li><a id="AddressBook" class="common">Address Book</a></li>
<li><a id="MyOrders" class="common">My Orders</a></li>
</ul>
</div>
<div id="divDynamic" class="order">
</div>
</body>
jQuery单击链接即可显示部分视图
<script type="text/javascript">
$(document).ready(function () {
$('.common').click(function () {
var pageid = this.id;
LoadPartialView(pageid);
});
});
function LoadPartialView(pageid) {
$("#divDynamic").empty();
$("#divDynamic").load("/WPindex/" + pageid,
function (response, status, xhr) {
if (status == "error") {
alert("An error occurred while loading the results.");
}
});
}
</script>
调节器
public ActionResult AccountDetails()
{
return PartialView();
}
[HttpPost]
public ActionResult AccountDetails(string FirstName, string LastName,
string Email, string DOB,string PhoneNo, string Gender)
{
return PartialView(model);
}
jQuery更新局部视图值并在同一视图中加载局部视图
$(document).ready(function () {
$('.button').click(function () {
LoadPartialView();
});
});
function LoadPartialView() {
var FirstName = document.getElementById("FirstName").value;
var LastName = document.getElementById("LastName").value;
var Email = document.getElementById("Email").value;
var DOB = document.getElementById("DOB").value;
var PhoneNo = document.getElementById("PhoneNo").value;
var Gender = $('#Gender optionelected').attr('value');
$("#divDynamic").load("/ControllerName/AccountDetails?", {
'FirstName': FirstName,'LastName': LastName, 'Email': Email,
'DOB': DOB, 'PhoneNo': PhoneNo,'Gender':Gender
},
function (response, status, xhr) {
if (status == "error") {
alert("An error occurred while loading the results.");
}
});
}
我试图更新部分视图值并在同一View中显示部分视图。 使用部分视图时,我遇到了一个性能问题。 我的代码中有任何错误。 ? 我的方法是错误的吗?
在这两个AccountDetails
操作方法中都放置断点。
我认为load方法在请求中使用get方法,而您的第二个action方法则用HttpPost
属性修饰。
尝试使用jQuery的ajax
方法: jQuery.ajax
用这个:
var myUrl = "/ControllerName/AccountDetails?FirstName=" + FirstName +
"&LastName=" + LastName +
// ... other query strings ...
$.ajax({
url: myUrl,
success: function (data, textStatus, jqXHR) {
$("#divDynamic").html(jqXHR.reponseText);
},
error: function (jqXHR, textStatus, errorThrown) {
alert(jqXHR.responesText);
}
// ... any other ajax options ...
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.