javascript - 动态更改 View 中的 GSP 模板

标签 javascript jquery grails

我想根据选择组件中选择的值刷新模板。

通常,我想在 View 中加载 3 个模板:

  • _templateA.gsp
  • _templateB.gsp
  • _templateC.gsp

在我的 GSP View 中,我有一个包含 3 个选项的选择组件:

  • 一个
  • B
  • C

如何动态更改代码中加载的模板:

<g:render template="*myTemplate*"/>

在select组件的onChange事件上? (如果我选择“A”,则加载 templateA,然后如果我选择“B”,则删除 templateA 并加载 templateB)

最佳答案

在下面的示例中,我们使用序列化将表单内容发布到 /myController/myAction 操作。

然后根据所选选项,我们呈现适当的模板并更新 View 中的 myDiv div。

普惠制:

<!DOCTYPE html>
<html>
<head>
<script type="text/javascript">
    $( document ).ready( function() {
        $( '#mySelect' ).on( 'change' , function (event) {
            $.ajax({
                url: "/myController/myAction",
                type: "POST",
                data: $( '#myForm' ).serialize(),
                success: function ( data ) {
                    $( '#myDiv' ).html( data );
                },
                error: function( j, status, eThrown ) { console.log( 'Error ' + eThrown ) }
            });
        });
    });
</script>
</head>
<body>
<g:form name="myForm">
    <g:select name="mySelect" from="${['A', 'B', 'C']}" />
</g:form>

<div id="myDiv"></div>
</body>
</html>

Controller :

def myAction() {
    render template: "template${params.mySelect}"
}

关于javascript - 动态更改 View 中的 GSP 模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43988575/

相关文章:

jquery - 如果值为 false 则停止 ajax 调用(在任何 ajax 调用之前)

grails - 在grails中使用elasticsearch查询嵌套字段

javascript - 处理 HTML 中的移动元素的更好方法是什么?

javascript - 根据输入字段上的用户信息创建动态链接 URL

javascript - 是否需要使用 load() 两次将同一文件附加到两个不同的元素

jQuery:先插入一个字符,然后调用函数

grails - ImageMagick 和 Grails 不工作

grails - Paypal Sandbox IPN 总是失败

javascript - IE 中的页面加载时,动画 gif 不会显示动画

javascript - 使用 div 重新创建行为 "background-attachment: fixed"