我有一个看起来很像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 回答
如果您的目标是简单地有条件地删除该变量,那么一种方法是: