祝大家新年快乐,
我正在开展一个项目,我必须在对话框(模态窗口)窗口中显示“列表”中每条记录的详细信息,同时用户单击列表中每条记录的链接。我试图使用GrailUI插件完成此任务。这是我的代码:
<gui:dialog width="300px"
controller="tag"
action="showTags"
params=" [id:userInstance.userId]"
update="dialogData"
draggable="true"
triggers="[show:[type:'link', text:'Show Tags', on:'click']]"
modal="true">
<div id='dialogData'>This will be updated by the controller action....</div>
由于某种原因,对话框标记未触发控制器操作。它打开对话框窗口,但只显示此消息“这将由控制器操作更新....”。它没有显示控制器动作渲染输出(视图)。有人能帮助我理解我做错了吗?
Jquery和jquery-ui是我在项目中使用的其他插件。
感谢您的帮助。
修改
def test(Integer max) {
....
....
userInstanceList = User.list(params)
render (view: "test", model: [userInstanceList: userInstanceList, userInstanceTotal: User.count()])
}
def showTags () {
def user = User.findByUserId(params.id)
def tagInstanceList = user.tags
render(view: "test", model: [tagInstanceList: tagInstanceList])
}
答案 0 :(得分:2)
如果您想将某些内容提交到远程,则需要设置form="true"
。然后,可以在对话框标记内放置任何表单元素,而无需定义表单。当form =“true”时,对话框会创建自己的表单。
以下是我测试过的一个例子:
<强> test.gsp:强>
<html>
<head>
....
<r:require modules="grailsui-dialog"/>
</head>
<body class="yui-skin-sam">
<gui:dialog width="300px"
controller="test"
action="showTags"
params=" [id:userInstance.userId]"
form="true" <!-- the key to remote submit -->
update="dialogData"
draggable="true"
triggers="[show:[type:'link', text:'Show Tags', on:'click']]"
modal="true" >
<!-- You can put any input element here, which will be submitted in the form-->
<div id='dialogData'>This will be updated by the controller action....</div>
</gui:dialog>
</body>
</html>
<强>的TestController:强>
class TestController {
def test() {
.........
}
def showTags() {
def user = User.findByUserId(params.id)
def tagInstanceList = user.tags
render(template: "ajaxResponse", model: [tagInstanceList: tagInstanceList, user:user]) //render a template, not a view
}
对于Ajax请求,您无法呈现视图,而视图将替换原始页面。相反,您应该发回一个模板,其中包含您要在对话框中显示的标记:
<强> _ajaxResponse.gsp 强>
<h3>Tag List of user ${user.username}</h3>
<g:each in="${tagInstanceList}" var="tag">
<p>${tag}</p>
</g:each>