Як мені зробити частковий вигляд за допомогою jquery?
Ми можемо надати частковий вид таким чином:
<% Html.RenderPartial("UserDetails"); %>
Як ми можемо зробити те ж саме, використовуючи jquery?
Як мені зробити частковий вигляд за допомогою jquery?
Ми можемо надати частковий вид таким чином:
<% Html.RenderPartial("UserDetails"); %>
Як ми можемо зробити те ж саме, використовуючи jquery?
Відповіді:
Ви не можете надати частковий вигляд, використовуючи лише jQuery. Однак ви можете зателефонувати за методом (дією), який зробить для вас частковий вигляд і додасть його на сторінку за допомогою jQuery / AJAX. Нижче у нас є обробник натискань на кнопку, який завантажує URL-адресу для дії з атрибута даних на кнопці та запускає GET-запит на заміну DIV, що міститься в частковому огляді, оновленим вмістом.
$('.js-reload-details').on('click', function(evt) {
evt.preventDefault();
evt.stopPropagation();
var $detailDiv = $('#detailsDiv'),
url = $(this).data('url');
$.get(url, function(data) {
$detailDiv.replaceWith(data);
});
});
де контролер користувача має дії, названі деталями:
public ActionResult Details( int id )
{
var model = ...get user from db using id...
return PartialView( "UserDetails", model );
}
Це припускаючи, що ваш частковий вигляд є контейнером з ідентифікатором, detailsDiv
щоб ви просто замінили всю річ вмістом результату виклику.
Кнопка батьківського перегляду
<button data-url='@Url.Action("details","user", new { id = Model.ID } )'
class="js-reload-details">Reload</button>
User
це ім'я контролера та details
ім'я дії в @Url.Action()
. Часткове подання користувачаDetails
<div id="detailsDiv">
<!-- ...content... -->
</div>
Для цього я використовував навантаження Ajax:
$('#user_content').load('@Url.Action("UserDetails","User")');
UserDetails
- назва дії, а не частковий погляд, правда?
@Url.Action("ActionName","ControllerName", new { area = "AreaName" } )
замість цього функцію Handcoding .
@tvanfosson скелює своєю відповіддю.
Однак я б запропонував покращення в межах js та невелику перевірку контролера.
Коли ми використовуємо @Url
помічник для виклику дії, ми отримуємо форматований html. Було б краще оновити вміст ( .html
), а не власне елемент ( .replaceWith
).
Детальніше про те: Яка різниця між jQuery's substituWith () та html ()?
$.get( '@Url.Action("details","user", new { id = Model.ID } )', function(data) {
$('#detailsDiv').html(data);
});
Це особливо корисно на деревах, де вміст можна змінити кілька разів.
На контролері ми можемо повторно використовувати дію залежно від запитувача:
public ActionResult Details( int id )
{
var model = GetFooModel();
if (Request.IsAjaxRequest())
{
return PartialView( "UserDetails", model );
}
return View(model);
}
Ще одна річ, яку ви можете спробувати (на основі відповіді tvanfosson), це:
<div class="renderaction fade-in"
data-actionurl="@Url.Action("details","user", new { id = Model.ID } )"></div>
А потім у розділі сценаріїв вашої сторінки:
<script type="text/javascript">
$(function () {
$(".renderaction").each(function (i, n) {
var $n = $(n),
url = $n.attr('data-actionurl'),
$this = $(this);
$.get(url, function (data) {
$this.html(data);
});
});
});
</script>
Це робить ваш @ Html.RenderAction за допомогою ajax.
І щоб зробити все симпатичним sjmansy, ви можете додати ефект зникнення за допомогою цього css:
/* make keyframes that tell the start state and the end state of our object */
@-webkit-keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@-moz-keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
.fade-in {
opacity: 0; /* make things invisible upon start */
-webkit-animation: fadeIn ease-in 1; /* call our keyframe named fadeIn, use animattion ease-in and repeat it only 1 time */
-moz-animation: fadeIn ease-in 1;
-o-animation: fadeIn ease-in 1;
animation: fadeIn ease-in 1;
-webkit-animation-fill-mode: forwards; /* this makes sure that after animation is done we remain at the last keyframe value (opacity: 1)*/
-o-animation-fill-mode: forwards;
animation-fill-mode: forwards;
-webkit-animation-duration: 1s;
-moz-animation-duration: 1s;
-o-animation-duration: 1s;
animation-duration: 1s;
}
Чоловік, якого я люблю mvc :-)
<div class="renderaction fade-in" ...></div>
елементів.
Вам потрібно буде створити дію на своєму контролері, яка повертає виведений результат часткового перегляду або контролю "UserDetails". Потім просто використовуйте Http Отримати або Опублікувати з jQuery, щоб викликати Дію, щоб відобразити відображений HTML-код.
Використовуючи стандартний дзвінок Ajax для досягнення того ж результату
$.ajax({
url: '@Url.Action("_SearchStudents")?NationalId=' + $('#NationalId').val(),
type: 'GET',
error: function (xhr) {
alert('Error: ' + xhr.statusText);
},
success: function (result) {
$('#divSearchResult').html(result);
}
});
public ActionResult _SearchStudents(string NationalId)
{
//.......
return PartialView("_SearchStudents", model);
}
Якщо вам потрібно посилатися на динамічно генероване значення, ви також можете додати параметри рядка запиту після @ URL.Акція так:
var id = $(this).attr('id');
var value = $(this).attr('value');
$('#user_content').load('@Url.Action("UserDetails","User")?Param1=' + id + "&Param2=" + value);
public ActionResult Details( int id, string value )
{
var model = GetFooModel();
if (Request.IsAjaxRequest())
{
return PartialView( "UserDetails", model );
}
return View(model);
}