首页 文章

web2py:如何更新表单字段值onvalidation

提问于
浏览
0

我有一个看起来很像web2py-docs中的样本:

http://web2py.com/books/default/chapter/29/07/forms-and-validators#onvalidation

车型/ db.py:

db.define_table('numbers',
    # Field('user_id', 'reference auth_user'),
    Field('user_id', 'integer'),
    Field('b', 'boolean'),
    Field('c', 'integer')

# db.numbers.user_id.requires = IS_IN_DB(db, db.auth_user.id)
db.numbers.user_id.writable = db.numbers.user_id.readable = False
db.numbers.id.writable = db.numbers.id.readable = False

控制器/ default.py:

def my_form_processing(form):
    if not form.vars.b:
       form.vars.c = None

# @auth.requires_login()   
def insert_numbers():
   # record = db(db.numbers.user_id==auth.user_id).select().first()
   record = db(db.numbers.user_id=1).select().first()
   db.numbers.c.show_if = (db.numbers.b == True)
   form = SQLFORM(db.numbers, record)
   if form.process(onvalidation=my_form_processing).accepted:
       session.flash = 'record inserted'
       redirect(URL())
   return dict(form=form)

但增加了一些“魔力”:

  • 在我的原始代码中,表单要求您登录并始终使用user_id == auth_id加载记录 . 为简化起见,始终加载user_id == 1的记录 .

  • 如果未选中复选框'b',请隐藏字段'c'(请参阅:Conditional fields

  • 如果未选中复选框'b'并且提交了表单,则清除值'c'(请参阅:onvalidation

  • FTR:如果记录不存在,它将被INSERTed,如果它已经存在,它将被UPDATEd . (web2py的魔法) .

这很好用(如果'b'为false,则c的数据库值设置为NULL)但这里是catch:

  • 检查'b'(显示字段'c')并在'c'中输入值并提交表格 . (b = True,c =数据库中的$ value) - >很好 .

  • 再次显示表单,并在'c' - >罚款中检查'b'和$值 .

  • 取消选中'b'(字段'c'将隐藏)并提交表单 . (b = False,c = Null在数据库中(因为onvalidation = my_form_processing)) - >也好!

  • 仅使用未选中的'b'再次显示该表单,但如果再次检查'b',则字段'c'仍然具有$ value(而不是空字段) .

如何清除字段'c'的形式值? (如果我只是在'b'为False时重新加载页面,'c'将是一个空字段 . 此问题仅在提交时出现) .

有人可以帮我这个吗?

1 回答

  • 0

    如果您的目标是简单地有条件地删除该变量,那么一种方法是:

    def insert_numbers():
       record = db(db.numbers.user_id=1).select().first()
       db.numbers.c.show_if = (db.numbers.b == True)
       form = SQLFORM(db.numbers, record)
    
       if form.validate(message_onsuccess = 'record inserted'):
           if not form.vars.b:
              del form.vars.c
           db['numbers'].insert(**form.vars)
           db.commit()   # just to be safe
           redirect( URL(...) )
       return dict(form=form)
    

相关问题