我认为我没有正确地使用类变量。在clientFormPage类中,我将活动的_窗体初始化为"f1_窗体"。在我发布第一个表单后,我想将活动的_表单前进到'f2_表单',但是它会一直重置为'f1_表单'。最好的方法是什么?
class ClientFormPage(PageHandler):
active_form = 'f1_form'
def render_form(self, f1='hidden', f2='hidden', **kw):
self.render('clientforms.html', form1=f1, form2=f2, **kw)
def get(self):
self.render_form(f1='')
def get_form2(self):
self.render_form(f2='')
def post(self):
if self.active_form == 'f1_form':
foo = self.request.get('foo')
if not foo:
self.render_form(f1_form='', foo=foo,
foo_error='has-error has-feedback')
else:
self.active_form = 'f2_form' # This assignment is not sticking
self.get_form2()
return
if self.active_form == 'f2_form':
bar = self.request.get('bar')
if not bar:
self.render_form(f1_form='', bar=bar,
bar_error='has-error has-feedback')
else:
self.active_form = 'f3_form'
self.get_form3()
return
class myClass(object):
def __init__(self):
def helper(self, jsonInputFile):
values = jsonInputFile['values']
ip = values['ip']
username = values['user']
password = values['password']
return values, ip, username, password
def checkHostname(self, jsonInputFile):
values, ip, username, password = self.helper
print values
print '---------'
print ip
print username
print password
init方法初始化类。helper函数只保存一些变量/数据/属性,并在调用它时将它们释放给其他方法。这里的jsonInputFile是一些json。check hostname是一种写入某些设备/服务器并检查主机名的方法,但它需要IP、用户名和密码,并通过调用helper方法提供。
如果我很好地理解您的代码和注释,那么您需要在请求之间保留状态(活动表单)。要做到这一点,你必须使用饼干。
不能在请求之间保存webapp2请求处理程序类中的状态。为每个请求创建一个新的处理程序类。
请参阅文档:http://webapp-improved.appspot.com/api/webapp2_extras/sessions.html
另一种方法是将您的活动窗体的名称保存在HTML表单的隐藏输入中。
这种隐藏的输入方法看起来正是我所寻找的,但是它似乎对我不起作用。我已经将它添加到我的HTML模板中:。我还将此添加到了我的clientFormPage类下:def post(self):active_form=self.request.get('active_form')self.response.write('active form:'+active_form)
当我查看最终写入时,它只显示"active form:",不显示任何活动的"form"值。我还没搞清楚价值在哪里。我是否缺少隐藏输入的内容?
它应该很容易调试。如果隐藏的输入包含活动表单值,请首先查看HTML表单。
你可以使用__init__魔法方法
class ClientFormPage(PageHandler):
def __init__(self):
self.active_form = 'f1_form'
这将允许您具有特定于实例的属性,而不是像在原始代码中那样具有类属性。
差异的快速演示:
python-为什么在类中使用"self"?
我刚删除了我的类变量行,并用两个初始行替换了它。我不清楚webapp2如何调用它,但我得到一个类型错误:uuinit_uu()只接受1个参数(给定3个)。这促使我改变到Defy-iNITTY(自我,FoO,Bar)。这一次,我得到了AbditError:"NoType"对象没有属性"路由"。我不确定我是否提供了足够的数据来解决这个问题。有什么明显的吗?
@bholben看起来PageHandler对象是在实例化时传递的参数。将定义更改为def __init__(self, *args, **kwargs):并在属性创建之前插入super(PageHandler, self).__init__(*args, **kwargs)。