- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我创建了一个宏来处理表单错误,如下所示:
{% macro render_field_with_errors(field) %}
<p>
{{ field.label }} {{ field(**kwargs)|safe }}
{% if field.errors %}
<ul>
{% for error in field.errors %}
<li style="color: red;">{{ error }}</li>
{% endfor %}
</ul>
{% endif %}
</p>
{% endmacro %}
{% macro render_field(field) %}
<p>{{ field(**kwargs)|safe }}</p>
{% endmacro %}
我的forms.py如下:
from flask.ext.wtf import Form, TextField, BooleanField, PasswordField, RadioField, SelectMultipleField
from flask.ext.wtf import Required
class LoginForm(Form):
username = TextField('email', validators = [Required()])
password = PasswordField('password', validators=[Required()])
remember_me = BooleanField('remember_me', default = False)
我的登录表单如下:
<!-- Login form -->
{% from "includes/_formhelpers.html" import render_field_with_errors %}
<form method="POST" action="/login" focus="first">
<div class="span5">
{{ login_form.hidden_tag() }}
{{ render_field_with_errors(login_form.username(placeholder="Username / Email", class="span10")) }}
<br>
{{ render_field_with_errors(login_form.password(placeholder="Password", class="span10")) }}
<br>
<div class="qp-log">
{{ render_field_with_errors(login_form.remember_me(class="qp-login", value="remember_me")) }} Remember Me
<br>
<button type="submit" class="btn qp-btn" style="height:30px;width:56px;">Login</button>
<button type="Reset" class="btn">Clear</button>
</div>
<div class="qp-pass">
Forgot Password? <a href ="#">click here</a>
</div>
</div>
<div class="span2">
<br>
<br>
<br>
<img src="{{ url_for('static', filename='img/or_icon.gif') }}">
</div>
<div class="span5">
<center>
<br>
<button class="btn btn-facebook">
<small>Connect with</small>
<big> Facebook </big>
</button>
<h4> or </h4>
<button type="Submit" class="btn qp-btn">
<a href="signup.html" style="color:white;">Sign Up for Free</a>
</button>
</center>
</div>
</form>
<!-- Form End -->
我收到以下错误:
Traceback (most recent call last):
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/flask/app.py", line 1701, in __call__
return self.wsgi_app(environ, start_response)
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/flask/app.py", line 1689, in wsgi_app
response = self.make_response(self.handle_exception(e))
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/flask/app.py", line 1687, in wsgi_app
response = self.full_dispatch_request()
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/flask/app.py", line 1360, in full_dispatch_request
rv = self.handle_user_exception(e)
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/flask/app.py", line 1358, in full_dispatch_request
rv = self.dispatch_request()
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/flask/app.py", line 1344, in dispatch_request
return self.view_functions[rule.endpoint](**req.view_args)
File "/home/rahul/git/webapp/webapp/routes.py", line 14, in index
return render_template("public/index.html", login_form=login_form)#, registration_form=registration_form)
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/flask/templating.py", line 125, in render_template
context, ctx.app)
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/flask/templating.py", line 107, in _render
rv = template.render(context)
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/jinja2/environment.py", line 969, in render
return self.environment.handle_exception(exc_info, True)
File "/home/rahul/git/webapp/venv/lib/python2.7/site-packages/jinja2/environment.py", line 742, in handle_exception
reraise(exc_type, exc_value, tb)
File "/home/rahul/git/webapp/webapp/templates/public/index.html", line 1, in top-level template code
{% extends "public/base.html" %}
File "/home/rahul/git/webapp/webapp/templates/public/base.html", line 1, in top-level template code
{% extends 'layout.html' %}
File "/home/rahul/git/webapp/webapp/templates/layout.html", line 35, in top-level template code
{% block content %}{% endblock %}
File "/home/rahul/git/webapp/webapp/templates/public/index.html", line 4, in block "content"
{% include 'public/login.html' %}
File "/home/rahul/git/webapp/webapp/templates/public/login.html", line 6, in top-level template code
{{ render_field_with_errors(login_form.username(placeholder="Username / Email", class="span10")) }}
File "/home/rahul/git/webapp/webapp/templates/includes/_formhelpers.html", line 3, in template
{{ field.label }} {{ field(**kwargs)|safe }}
AttributeError: 'HTMLString' object has no attribute '__call__'
I am not getting whats wrong in the code? If I remove macro from html file and instead include for loop for error handling in html form, it works perfect. What I think is, the placeholder and class included in element which causes the error, but not sure why?
最佳答案
我最近遇到了类似的问题,我认为问题出在login.html中的这个模式
{{ render_field_with_errors(login_form.password(placeholder="Password", class="span10")) }}
您正在将占位符和类传递给登录表单,此时它只是 wtf 生成的一段 html。如果我在我的 flask 版本中尝试这个,即使其余代码不同,我也会得到完全相同的错误。如果我在助手中传递占位符和类,错误就会消失:
{{ field(class="span10",placeholder="Password",**kwargs)|safe }}
如果您不能在帮助程序中传递通用占位符和类,您始终可以在模板中指定它们
<div class=span10> {{render_field_with_errors(loginForm.password) }} </div>
更新:其实我又查了一下,你也可以这样做:
{{ render_field_with_errors(login_form.password,placeholder="Password", class="span10") }}
这是有道理的——您将关键字参数传递给一个字段。您没有向它传递一个带参数的函数,它无法处理这些参数,而只是传递几个关键字参数。希望这会有所帮助。
关于python - flask 属性错误 : 'HTMLString' object has no attribute '__call__' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18143961/
你能比较一下属性吗 我想禁用文本框“txtName”。有两种方式 使用javascript,txtName.disabled = true 使用 ASP.NET, 哪种方法更好,为什么? 最佳答案 我
Count 属性 返回一个集合或 Dictionary 对象包含的项目数。只读。 object.Count object 可以是“应用于”列表中列出的任何集合或对
CompareMode 属性 设置并返回在 Dictionary 对象中比较字符串关键字的比较模式。 object.CompareMode[ = compare] 参数
Column 属性 只读属性,返回 TextStream 文件中当前字符位置的列号。 object.Column object 通常是 TextStream 对象的名称。
AvailableSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。 object.AvailableSpace object 应为 Drive 
Attributes 属性 设置或返回文件或文件夹的属性。可读写或只读(与属性有关)。 object.Attributes [= newattributes] 参数 object
AtEndOfStream 属性 如果文件指针位于 TextStream 文件末,则返回 True;否则如果不为只读则返回 False。 object.A
AtEndOfLine 属性 TextStream 文件中,如果文件指针指向行末标记,就返回 True;否则如果不是只读则返回 False。 object.AtEn
RootFolder 属性 返回一个 Folder 对象,表示指定驱动器的根文件夹。只读。 object.RootFolder object 应为 Dr
Path 属性 返回指定文件、文件夹或驱动器的路径。 object.Path object 应为 File、Folder 或 Drive 对象的名称。 说明 对于驱动器,路径不包含根目录。
ParentFolder 属性 返回指定文件或文件夹的父文件夹。只读。 object.ParentFolder object 应为 File 或 Folder 对象的名称。 说明 以下代码
Name 属性 设置或返回指定的文件或文件夹的名称。可读写。 object.Name [= newname] 参数 object 必选项。应为 File 或&
Line 属性 只读属性,返回 TextStream 文件中的当前行号。 object.Line object 通常是 TextStream 对象的名称。 说明 文件刚
Key 属性 在 Dictionary 对象中设置 key。 object.Key(key) = newkey 参数 object 必选项。通常是 Dictionary 
Item 属性 设置或返回 Dictionary 对象中指定的 key 对应的 item,或返回集合中基于指定的 key 的&
IsRootFolder 属性 如果指定的文件夹是根文件夹,返回 True;否则返回 False。 object.IsRootFolder object 应为&n
IsReady 属性 如果指定的驱动器就绪,返回 True;否则返回 False。 object.IsReady object 应为 Drive&nbs
FreeSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。只读。 object.FreeSpace object 应为 Drive 对象的名称。
FileSystem 属性 返回指定的驱动器使用的文件系统的类型。 object.FileSystem object 应为 Drive 对象的名称。 说明 可
Files 属性 返回由指定文件夹中所有 File 对象(包括隐藏文件和系统文件)组成的 Files 集合。 object.Files object&n
我是一名优秀的程序员,十分优秀!