web2py CRUD.create() 表单中的字段表示

web2py CRUD.create() field representation in forms

本文关键字:字段 表示 表单 CRUD create web2py      更新时间:2023-09-26

>例如我有这个字段

Field('yourref', type='string',
          label=T('Your reference')),

在 HTML 中显示为输入

<input id='table_yourref' name='yourref' value=''/>

我想这样展示它

<input id='table_yourref' name='yourref' value=''/>
<a onclick='add()'>Add</a>
<a onclick='remove()'>Remove</a>

add()remove()是用于添加或删除字段的 jQuery 函数

最好的方法可能是创建自定义小部件:

def mywidget(field, value):
    return CAT(INPUT(_name=field.name,
                     _id='%s_%s' % (field._tablename, field.name),
                     _class=field.type,
                     _value=value, requires=field.requires),
               A('Add', _onclick='add()'),
               A('Remove', _onclick='remove()'))
...
Field('yourref', type='string', label=T('Your reference'),
      widget=mywidget)

您还可以使用服务器端 DOM 在创建表单后将链接插入到表单中:

form = crud.create(db.mytable)
form.element('#mytable_myfield__row .w2p_fw').append(A('Add', _onclick='add()'))
form.element('#mytable_myfield__row .w2p_fw').append(A('Remove', _onclick='remove()'))

自定义小部件的优点是它将应用于基于 db.mytable 创建的所有表单,而 DOM 方法必须单独应用于每个表单。