Como renderizo a vista parcial usando jquery?
Podemos renderizar a vista parcial assim:
<% Html.RenderPartial("UserDetails"); %>
Como podemos fazer o mesmo usando jquery?
Como renderizo a vista parcial usando jquery?
Podemos renderizar a vista parcial assim:
<% Html.RenderPartial("UserDetails"); %>
Como podemos fazer o mesmo usando jquery?
Respostas:
Você não pode renderizar uma vista parcial usando apenas jQuery. Você pode, no entanto, chamar um método (ação) que renderize a exibição parcial para você e a adicione à página usando jQuery / AJAX. Abaixo, temos um manipulador de cliques de botão que carrega a URL da ação de um atributo de dados no botão e dispara uma solicitação GET para substituir o DIV contido na exibição parcial pelo conteúdo atualizado.
onde o controlador do usuário tem uma ação chamada detalhes que faz:
Isso pressupõe que sua visualização parcial seja um contêiner com o ID,
detailsDiv
para que você substitua a coisa toda pelo conteúdo do resultado da chamada.Botão de exibição dos pais
User
é o nome do controlador edetails
é o nome da ação em@Url.Action()
. Visualização parcial UserDetailsfonte
Eu usei o carregamento do ajax para fazer isso:
fonte
UserDetails
nome de uma ação é não uma visão parcial, certo?@Url.Action("ActionName","ControllerName", new { area = "AreaName" } )
, em vez de fazer handcoding .@tvanfosson arrasa com sua resposta.
No entanto, eu sugeriria uma melhoria dentro de js e uma pequena verificação de controlador.
Quando usamos o
@Url
helper para chamar uma ação, receberemos um html formatado. Seria melhor atualizar o conteúdo (.html
) e não o elemento real (.replaceWith
).Mais informações em: Qual é a diferença entre replaceWith () do jQuery () e html ()?
Isso é especialmente útil em árvores, onde o conteúdo pode ser alterado várias vezes.
No controlador, podemos reutilizar a ação, dependendo do solicitante:
fonte
Outra coisa que você pode tentar (com base na resposta do tvanfosson) é:
E então na seção de scripts da sua página:
Isso renderiza seu @ Html.RenderAction usando ajax.
E para tornar tudo sans-manha, você pode adicionar um efeito de desvanecimento usando este css:
Cara eu amo mvc :-)
fonte
<div class="renderaction fade-in" ...></div>
elementos.Você precisará criar uma Ação no seu Controller que retorne o resultado renderizado da exibição ou controle parcial "UserDetails". Em seguida, basta usar um Http Get ou Post do jQuery para chamar a Action para que o html renderizado seja exibido.
fonte
Usando chamada Ajax padrão para obter o mesmo resultado
fonte
Eu fiz assim.
Detalhes Método:
fonte
Se você precisar fazer referência a um valor gerado dinamicamente, também poderá anexar parâmetros de sequência de caracteres de consulta após o @ URL.
fonte