在Flask中,当我在Jinja2模板中呈现表单时(content = PageDownField()
,后者是TextAreaField
的子类):
{{ form.content(class_='form-control') }}
我收到错误:
__call__() got multiple values for keyword argument 'class_'
这源于以下代码行(widget.py),其中class_
已被归因。
html = super(PageDown, self).__call__(field, id = 'flask-pagedown-' + field.name, class_ = 'flask-pagedown-input', **kwargs)
快速而简单的解决方案是修改Flask扩展的PageDown
类。
有更优雅的方法来解决问题吗?谢谢!
答案 0 :(得分:0)
class_
中可能已有kwargs
个值。
试试这个:
kwargs.update(class_='flask-pagedown-input', id='flask-pagedown-' + field.name)
html = super(PageDown, self).__call__(field, **kwargs)
答案 1 :(得分:0)
如果这个CSS类对你很重要,我担心你必须编写自己的小部件代码,因为在这个文件中有很多其他硬编码的东西(就像前后HTML中的其他CSS类一样)字符串)。
from wtforms.widgets import HTMLString, TextArea
pagedown_pre_html = '''
<div class="form-group">
'''
pagedown_post_html = '''
</div>
<script type="text/javascript">
f = function() {
if (typeof flask_pagedown_converter === "undefined")
flask_pagedown_converter = Markdown.getSanitizingConverter().makeHtml;
var textarea = document.getElementById("flask-pagedown-%s");
var preview = document.createElement('div');
preview.className = 'help-block';
textarea.parentNode.insertBefore(preview, textarea.nextSibling);
textarea.onkeyup = function() { preview.innerHTML = flask_pagedown_converter(textarea.value); }
textarea.onkeyup.call(textarea);
}
if (document.readyState === 'complete')
f();
else if (window.addEventListener)
window.addEventListener("load", f, false);
else if (window.attachEvent)
window.attachEvent("onload", f);
else
f();
</script>
'''
class PageDownBootstrap(TextArea):
def __call__(self, field, **kwargs):
html = super(PageDownBootstrap, self).__call__(field, id = 'flask-pagedown-' + field.name, class_ = 'form-control', **kwargs)
return HTMLString(pagedown_pre_html + html + pagedown_post_html % field.name)
请注意类的第15行替换预览块,这可能不是您想要的。根据您的需要进行更改。
另一个解决方案是使用LESS形式的Bootstrap(我猜它是form-control
来自的地方)并使flask-pagedown*
类从Bootstrap继承正确的类。