- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 django 2.1 中开发应用程序并使用 bootstrap 4
这需要用户注册表格。在我看到的大多数示例中,都显示了单列表单的示例,这对于字段很少的表单来说已经足够了,但是对于更复杂的表单来说,它会很难看,因为您必须滚动浏览字段的数量。我想为此设计一种形式 Server side
调查了一下我发现这个教程Advanced Form Rendering with Django Crispy Forms其中使用的是
Django Crispy Forms你会得到你想要的形式。但是我不想使用它,所以尝试手动完成并完成此操作。我认为它可以改进一点,因为它不是那么干净,但是它是达到与使用 Django Crispy Forms 相同的结果的替代方法。我认为这可以使用 ajax 来完成,但到目前为止我从未使用过它。
他还会问自己,如果有人已经这样做了,为什么要把这件事复杂化,这是一种无需任何魔法即可了解一切如何运作的方法。
View .py
def sign_up(request):
if 'code_user' in request.session:
return redirect('home')
elif request.method == 'POST':
form = SignupForm(request.POST)
if form.is_valid():
user = form.save()
request.session['code_user'] = user.code
request.session['username'] = user.username
return redirect('home')
else:
for field in form:
if field.errors:
form.fields[field.name].widget.attrs['class'] = 'form-control is-invalid'
return render(request, 'blog/signup.html', {'form': form})
else:
form = SignupForm()
return render(request, 'blog/signup.html', {'form': form})
class SignupForm(forms.ModelForm):
class Meta:
model = User
fields = ['username', 'email', 'password', 'first_name', 'last_name', 'age', 'gender', 'country']
widgets = {
'username': forms.TextInput(attrs={'class': 'form-control', }),
'country': forms.Select(attrs={'class': 'form-control', }),
'first_name': forms.TextInput(attrs={'class': 'form-control', }),
'last_name': forms.TextInput(attrs={'class': 'form-control', }),
'age': forms.DateInput(attrs={'class': 'form-control', 'type': 'date'}),
'email': forms.EmailInput(attrs={'class': 'form-control', }),
'password': forms.PasswordInput(attrs={'class': 'form-control', }),
'gender': forms.Select(attrs={'class': 'form-control', }),
}
labels = {
'username': _('Username'),
'country': _('Country'),
'first_name': _('First Name'),
'last_name': _('Last Name'),
'age': _('Birthdate'),
'email': _('Email'),
'password': _('Password'),
'gender': _('Gender'),
}
error_messages = {
'username': {
'unique': _('The username is not available')
},
'first_name': {
'required': _('The field can not be empty')
},
'last_name': {
'required': _('The field can not be empty')
},
'password': {
'required': _('The field can not be empty')
}
}
{% extends 'blog/base.html' %}
{% block content %}
<div class="row justify-content-center" style="padding-top: 1rem">
<div class="col-md-10">
<div class="card">
<div class="card-header text-center">Sign up</div>
<div class="card-body">
<form method="POST">
{% csrf_token %}
<div class="form-row">
<div class="form-group col-md-4">
<label >{{ form.username.label }}</label>
{{ form.username }}
{% for error in form.username.errors %}
<div class="invalid-feedback">{{ error }}</div>
{% endfor %}
</div>
<div class="form-group col-md-4">
<label>{{ form.first_name.label }}</label>
{{ form.first_name }}
{% for error in form.first_name.errors %}
<div class="invalid-feedback">{{ error }}</div>
{% endfor %}
</div>
<div class="form-group col-md-4">
<label>{{ form.last_name.label }}</label>
{{ form.last_name }}
{% for error in form.last_name.errors %}
<div class="invalid-feedback">{{ error }}</div>
{% endfor %}
</div>
</div>
<div class="form-row">
<div class="form-group col-md-4">
<label >{{ form.age.label }}</label>
{{ form.age }}
{% for error in form.age.errors %}
<div class="invalid-feedback">{{ error }}</div>
{% endfor %}
</div>
<div class="form-group col-md-4">
<label >{{ form.gender.label }}</label>
{{ form.gender }}
{% for error in form.gender.errors %}
<div class="invalid-feedback">{{ error }}</div>
{% endfor %}
</div>
<div class="form-group col-md-4">
<label >{{ form.country.label }}</label>
{{ form.country}}
{% for error in form.country.errors %}
<div class="invalid-feedback">{{ error }}</div>
{% endfor %}
</div>
</div>
<div class="form-row">
<div class="form-group col-md-6">
<label >{{ form.email.label }}</label>
{{ form.email }}
{% for error in form.email.errors %}
<div class="invalid-feedback">{{ error }}</div>
{% endfor %}
</div>
<div class="form-group col-md-6">
<label >{{ form.password.label }}</label>
{{ form.password }}
{% for error in form.password.errors %}
<div class="invalid-feedback">{{ error }}</div>
{% endfor %}
</div>
</div>
<button type="submit" class="btn btn-primary">Sign in</button>
</form>
</div>
</div>
</div>
</div>
{% endblock %}
最佳答案
也许下面的帖子有帮助,它展示了如何使用 django-floppyforms 更好地组织前端文件
Better usage of JS & CSS inside Django
关于python - django-crispy-forms 的替代品,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55072876/
我不完全确定我理解 substitute 的作用,尽管我以前在它的代码中使用过。今天在shiny::exprToFunction中遇到了如下几行代码: function (expr, env = pa
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我最近发现了 crockford 的 Javascript supplant 函数。函数是这样的—— if (!String.prototype.supplant) { String.prot
在我工作的一些项目中,添加了一些具有这种语法的 block : var [code, name] = input.split("/"); console.log(code); console.log(
我对 JavaBeans 模式的憎恨就像一千个太阳的火焰一样燃烧。为什么? 冗长。现在是 2009 年。我不应该为一个属性写 7 LOC。如果他们有事件监听器,请捕获你的帽子。 没有类型安全的引用。没
是否有比 PHP 执行速度更快且具有相同功能集(例如对常见 RDBMS、Curl、Regex 等的支持)的替代品? 用 C 编写网站代码怎么样?效果如何?该平台是否独立并在每台服务器上运行? 最佳答案
我正在开始新项目。客户端界面基于 GWT(和 GXT),我没有说它是预先确定的。但是,我可以选择服务器端,这样我就可以玩得开心,并希望在这个过程中学到一些新东西。一些要求是: 与服务器的交换将通过使用
我目前使用 CentOS 5.6(Ghostscript 8 - ImageMagick-6.2.8) 我正在尝试将 pdf 的第一张图像转换为 jpg 文件。 我知道我当前的设置无法转换压缩的 pd
2021 年更新: 只使用 MathJax;您不应该再支持旧版本的 IE。 我想使用 MathJax 来显示 MathML 方程,但它在 IE 中的性能慢得令人无法接受(是的,我读过使用 Emulat
BinaryFormatter 序列化的 128³ 数组加倍,占用 50 MB 空间。序列化具有两个双字段的 128³ 结构数组需要 150 MB 和超过 20 秒的处理时间。 是否有快速简单的替代方
我发现 $.each 非常慢,如果包含大量各种 jQuery 效果,会给网页带来问题。 我想知道 $.each 是否有一个好的替代方案,例如: $('ul li').each(function() {
我正在编写一个Mac应用程序,它提供类似“测试”的功能。此应用程序(通过与服务器的连接)。基本上,该应用程序将为学生提供一个故事供阅读,然后是一系列问题(也来自服务器),用户可以(尝试)选择正确的答案
我喜欢 WPF,但我讨厌 XAML。 XAML 过于冗长,在 Microsoft 尝试对其进行扩展时出现语法问题(请参阅 StringFormat on Bindings),并且难以导航。 XAML
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足 Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以
有没有类似 SoftwareFx 的 PowerGadgets 的产品?我正在查看支持自动刷新的 powershell 的仪表控件。 最佳答案 检查 ShowUI 模块。 http://showui.
我正在开发一个项目,其中页面需要能够根据服务器的状态保持更新。 我喜欢 websocket,因为它们为我提供了一种从服务器推送消息的方法,但可用性是一个问题。 我需要通用方法在网络服务器和浏览器客户端
我最近一直在使用 openX 自托管广告管理软件,但它太慢了。 目标:我需要能够展示一个广告,获得 10 次点击,然后停用该广告,并且每天都这样做。 问题:当我将 openX 设置为每天 10 次点击
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我正在尝试实现一个简单的类,该类允许用户裁剪用于其个人资料图片的图像。这是一个 Java Web 应用程序。 我做了一些搜索,发现 java.awt 有一个 BufferedImage 类,这看起来(
只是一个关于 JQuery 的简单问题,我一直在使用phonegap 并使用 JQuery 制作了一些应用程序。其中一个运行速度非常慢,所以我一直在努力尽可能地精简它。 我一直在考虑的一个更改是用更小
我是一名优秀的程序员,十分优秀!