2

我有一个 Grails 项目,我在其中使用大量定制的脚手架模板来添加beforeUpdate模板方法,update这样我就可以轻松地自定义脚手架Controller,而不必分别生成然后编辑每个控制器。

不幸的是,这不起作用,只能beforeUpdate从脚手架调用。我怀疑这与 Groovy 用于将脚手架代码注入实际的代码生成有关Controller,但我找不到任何确认。

我要问的是解决问题的方法或解释为什么它不起作用。

下面是脚手架代码:

def beforeUpdate = {
    println "beforeUpdate from scaffold"
}

def update() {
    // call before update hook
    beforeUpdate()

    def ${propertyName} = ${className}.get(params.id)
    if (!${propertyName}) {
        flash.message = message(code: 'default.not.found.message', args: [message(code: '${domainClass.propertyName}.label', default: '${className}'), params.id])
        redirect(action: "list")
        return
    }
    [...]

和脚手架的控制器代码(没有被调用,虽然我相信它应该被调用):

class CalendarController {
    static scaffold = Calendar

    def beforeUpdate = {
            println "beforeUpdate from controller"
    }
}

我已经尝试过grails clean ;-)

更新

我最终意识到,由于 Grails 脚手架的设计方式,这简直是不可能的。关闭。

4

2 回答 2

1

您对这个问题有类似的问题- 基本上,脚手架的工作方式是脚手架模板生成一个单独的类,“真实”控制器委托给该类。因此,如果您希望生成的控制器调用您无法使用的真实控制器上的方法,则this需要获取对真实控制器对象的引用。

长话短说,使用

GrailsWebUtil.getControllerFromRequest(request).beforeUpdate()

而不仅仅是

beforeUpdate()

def update() {
    // call before update hook
    def realController = GrailsWebUtil.getControllerFromRequest(request)
    if(realController.hasProperty('beforeUpdate') &&
         realController.beforeUpdate instanceof Closure) {
      realController.beforeUpdate()
    } else {
      this.beforeUpdate()
    }

    def ${propertyName} = ${className}.get(params.id)
    if (!${propertyName}) {
        flash.message = message(code: 'default.not.found.message', args: [message(code: '${domainClass.propertyName}.label', default: '${className}'), params.id])
        redirect(action: "list")
        return
    }
    [...]
于 2013-06-04T10:07:14.010 回答
0

我最终意识到,由于 Grails 脚手架的设计方式,这根本不可能:通过将方法动态复制/创建到脚手架控制器中而不使用继承。

于 2013-06-04T06:34:52.873 回答