Вы можете использовать bindData
внутри контроллера. Этот метод имеет необязательные аргументы, которые позволяют вам явно указать, какие свойства должны быть включены или исключены привязкой, например
def map = ['var1':'property1', 'var2':'3']
def target = new MyClass()
// using inclusive map
bindData(target, map, [include:['var1', 'var2']])
// using exclusive map
bindData(target, this.params, [exclude:['var2']])
Если вы хотите выполнить привязку такого типа вне контроллера, используйте один из методов org.codehaus.groovy.grails.web.binding.DataBindingUtils
, например,
/**
* Binds the given source object to the given target object performing type conversion if necessary
*
* @param object The object to bind to
* @param source The source object
* @param include The list of properties to include
* @param exclude The list of properties to exclud
* @param filter The prefix to filter by
*
* @return A BindingResult or null if it wasn't successful
*/
public static BindingResult bindObjectToInstance(Object object, Object source, List include, List exclude, String filter)
Вот пример использования этого метода для выполнения той же привязки, что и при вызове «включающей карты» bindData
выше
def map = ['var1':'property1', 'var2':'3']
def target = new MyClass()
DataBindingUtils.bindObjectToInstance(target, map, ['var1', 'var2'], [], null)