Похоже, вы захотите использовать AJAX для этого.Один из способов сделать это - использовать комбинацию шаблонов и доменных объектов:
// grails-app/domain/ShippingOption.groovy
class ShippingOption = {
String method, // can be 'ground', 'sea', 'air', or 'general'
name // can be 'fedex', 'ups', etc.
def options = {
def meth = params.method ?: "general"
def comList = ShippingOption.findByMethod(meth)
render(template:"shippingList", model: [ commodityList: comList ])
}
}
И шаблон:
<!-- grails-app/views/_shippingList.gsp -->
<g:each var="opt" in="${commodityList}">
<option value="${opt.name}">${opt.name}</option>
</g:each>
И в вашем gsp с полем выбора на нем:
<!-- ... other stuff is before here ... -->
<g:select name="method" from="${['GENERAL', 'GROUND', 'SEA', 'AIR']}"
onchange="${remoteFunction(action:'options', update:'commodity',
params:''method=' + this.value' )}" />
<select id="commodity"></select>
Я уверен, что перепутал некоторый синтаксис, и вам определенно придется немного изменить его для работы с вашим кодом.Но, по крайней мере, у вас есть общая идея.
И чтобы использовать их, добавьте их в базу данных как ShippingOption
s.Вот один из способов сделать это.
["fedex", "ups"].each { name ->
def so = new ShippingMethod(method: "ground", name: name )
so.save()
}
PS: Вы также сможете динамически отображать методы доставки.
См. Также: remoteFunction , g: выберите , шаблоны и AJAX