我的网站的目的是有一个页面,我们称之为“随机问题!”
每次用户进入页面时,都会随机生成一组数字,他们必须正确回答问题:numbera + number b。
如果它们是正确的,它们会转到一个“正确”的页面,然后再将它们重定向回同一页面,并使用一组不同的数字。
现在,问题是,在第一页“随机问题!”,我想添加另一个问题。
views.朋友:
def form_handle(request):
if request.method == 'POST':
form = MyForm(request.POST) # if post method then form will be validated
if form.is_valid():
cd = form.cleaned_data
num1 = cd.get('num1')
a = request.session.get('a', 0)
b = request.session.get('b', 0)
if float(num1) == float(a + b):
# give HttpResponse only or render page you need to load on success
return render(request, 'sectipn1part1success', {})
else:
# if sum not equal... then redirect to custom url/page
return HttpResponseRedirect('rr/') # mention redirect url in argument
else:
a = random.randrange(5,10);
b = random.randrange(10,20);
request.session['a'] = a
request.session['b'] = b
question1 = ('What is ' + str(a) + ' + ' + str(b) + ' ?')
form = MyForm() # blank form object just to pass context if not post method
context = {
'form': form,
'a': a,
'b': b,
'question1': question1
}
return render(request, "section1part1.html", context)
正如你所看到的,现在它只做一个简单的问题风格,只是加法(问题1)。
我想补充一个问题,例如问题2,这可能类似于“什么是/ 2”。
像上面这样的东西可以使用类似Java SWITCH语句的东西来实现(我不确定Django是否有它,尽管它应该可以在没有它的情况下完成它)。将生成对应于另一个问题的随机数。然后,如果request.method =='POST'之后我必须使用另一个IF语句来计算正确的答案,因为每个新问题的计算方式都不同。
现在,上述将是短期内的一个好策略。
从长远来看,我不确定它是否理想。有没有更好的方法做这种事情或我的方式好吗?
我在考虑其他方式,包括:
**我应该注意哪些性能考虑因素? **
更新#1
好的,我已经开始实施上面提到的建议了。这是发生的事情:
调用Django视图 - >随机调用另一个视图函数并执行处理并返回上下文对象
else: #add another 'if' randomiser to selection question function randomly
context = question1(request)
context = question2(request)
return render(request, "section1part1.html", context)
这是好习惯/风格吗?我应该继续这样做吗?
form_handle
应该只负责处理表格。所有创造问题和答案的工作都应该通过其他方式完成。一旦你这样做,很容易切换问题类型,或产生无限循环的问题,或创建一个循环的问题列表,或...
这是一个Question
类的例子。您可以轻松创建返回(question, answer)
元组或任何其他各种问题/答案生成器的函数。
class Question(object):
def answer(self):
raise NotImplementedError
def question(self):
raise NotImplementedError
class AdditionQuestion(Question):
def __init__(self):
a_range = (5, 10)
b_range = (10, 20)
self.a = random.randrange(*a_range)
self.b = random.randrange(*b_range)
def answer(self):
return self.a + self.b
def question(self):
return 'What is {} + {}?'.format(self.a, self.b)
class MultiplicationQuestion(Question):
def __init__(self):
a_range = (100, 200)
b_range = (10, 20)
self.a = random.randrange(*a_range)
self.b = random.randrange(*b_range)
def answer(self):
return self.a * self.b
def question(self):
return 'What is {} * {}?'.format(self.a, self.b)
那么,你的代码只依赖于一个有object.question()
和object.answer()
的对象。如果你想要非数字答案,或者足够接近的答案(例如:3.3333足够接近3.333333)你可以将if float(num1) == float(answer):
更改为if compare_answers(num1, answer):
然后写一个compare_answers
函数。
def form_handle(request):
if request.method == 'POST':
form = MyForm(request.POST) # if post method then form will be validated
if form.is_valid():
cd = form.cleaned_data
num1 = cd.get('num1')
answer = request.session.get('answer', 0)
if float(num1) == float(answer):
# give HttpResponse only or render page you need to load on success
return render(request, 'sectipn1part1success', {})
else:
# if sum not equal... then redirect to custom url/page
return HttpResponseRedirect('rr/') # mention redirect url in argument
else:
question = AdditionQuestion()
answer = question.answer()
request.session['answer'] = answer
form = MyForm() # blank form object just to pass context if not post method
context = {
'form': form,
'answer': answer,
'question': question.question()
}
return render(request, "section1part1.html", context)
如果你想要一个随机的问题类型生成器,也可以使它成为自己的函数/对象。保持它与form_handle
分开,以便它易于更改:
def random_question():
class_ = random.choice([MultiplicationQuestion, AdditionQuestion])
return class_()
然后在这里更改以下行:
else:
question = AdditionQuestion()
至:
else:
question = random_question()