最后我最终使用了一个基于jQuery的解决方案。 Question here。我添加了类“数字”,并添加了jquery数字验证,而不是添加类型。但这是一个骇人听闻的解决方案,特别是当我们有html 5“号码”时。如果有人找到了解决办法,请回答。
形式:
def __init__(self,*args,**kwargs):
super(PropertyFloorForm, self).__init__(*args, **kwargs)
self.fields['number_of_units'].widget.attrs['class'] = "number"
在模板
$(document).ready(function() {
$(".number").keydown(function(event) {
// Allow: backspace, delete, tab, escape, and enter
if (event.keyCode == 46 || event.keyCode == 8 || event.keyCode == 9 || event.keyCode == 27 || event.keyCode == 13 ||
// Allow: Ctrl+A
(event.keyCode == 65 && event.ctrlKey === true) ||
// Allow: home, end, left, right
(event.keyCode >= 35 && event.keyCode <= 39)) {
// let it happen, don't do anything
return;
} else {
// Ensure that it is a number and stop the keypress
if (event.shiftKey || (event.keyCode < 48 || event.keyCode > 57) && (event.keyCode < 96 || event.keyCode > 105)) {
event.preventDefault();
}
}
});
});
clientside验证只是中途,你也应该验证serverside(你的表单的干净方法)。 – Jingo
是的,我正在那样做。但我的客户有特殊要求,他希望能够输入数字。 –