Grails验证:在formRemote之后,renderErrors没有恢复

时间:2011-10-13 11:01:21

标签: grails tags

这是在gsp

<g:if test="${hasError}">
    <div class="errors">
        <g:renderErrors bean="${eventInstance}" />
    </div>
</g:if>
<g:else >
    <div id="messageBox" class="message" style="display:none;">
        <g:message code="legalevent.save.success" args="[entityName]" default="Event saved successfully" />
    </div>
</g:else>
<g:formRemote name="eventForm" id="eventForm" url="[controller : 'search', action : 'saveLegalEvent']"  
                  update="eventFormDiv" action="${createLink(controller: 'search', action: 'saveLegalEvent')}" method="POST"
                  onSuccess="jQuery('#messageBox').show()">

我正在渲染一个用于更新的页面:

def saveLegalEvent = {

    def paramsView = params
    def eventPattern = /(event\.).*/
    def event = LegalEvent.findByLevId(params["levId"])
    def corrTxt = params["corrTxt"] as CorrectionText
    if(corrTxt.getCorrId()){
        corrTxt = CorrectionText.findByCorrId(corrTxt.getCorrId())
    }
    event.setCorrTxt(corrTxt)
    event.properties = params["event"] 
    def dataList = []
    def hasError = false
    def validated = event.validate()
    validated &= event.validateHistoryParams()
    if(validated)
        event.save(flush:true)
    else 
        hasError = true
    def errorsView = event.errors
    render(view:'leform', model:[attributeDataInstanceList:event.tags, lecInstance:event.leCode, eventInstance:event, hasError: hasError])
}

validateHistoryParams验证域类中通常不需要的一些参数。

def validateHistoryParams = { ->
    if(!changeRef || !changeRef.trim()) {
        this.errors.rejectValue('changeRef', 'event.changeRef.blank')
    }
    if(!corrTxt || !(corrTxt.corrTxt.trim() || corrTxt.corrId )) {
        this.errors.rejectValue('corrTxt', 'event.corrTxt.null')
    }

    !(this.hasErrors())
}

所有这些的问题是错误不会在gsp中呈现。 所有其他标签都可以正常运行,调试时我可以看到错误实际上在错误堆栈中。但最终,标签不会渲染它们。

正如您所看到的,没有重定向,所以我无法理解为什么在响应创建和渲染之间会以某种方式擦除错误......

1 个答案:

答案 0 :(得分:0)

在Groovy代码中,返回的参数名为hasError,GSP会检查hasErrors。我建议不要使用额外的变量,只需在GSP中查询bean本身。

我还认为你需要在formRemote元素中使用 那个错误,以便在表单提交后重新呈现。