Django中 form表单的使用

from django import forms

第一步:首先在models.py中定义一个表单模型

class RemarkForm(forms.Form):
        subject = forms.CharField(max_length=100 ,label= '留言标题')
        mail = forms.EmailField(label= '电子邮件')
        topic = forms.ChoiceField(choices=TOPIC_CHOICES,label= '选择评分')  
        message = forms.CharField(label= '留言内容',widget=forms.Textarea)
        cc_myself = forms.BooleanField(required= False ,label= '订阅该贴')

那个topic中的choices需要在models.py中定义一个数组.
TOPIC_CHOICES = (
        ('leve1', '差评'),
        ('leve2', '中评'),
        ('leve3', '好评'),
)

这样,之后在html显示的表单就采用这个模型的数据了。

另外还有一种定义表单模型的方式,那就是直接继承另一个models。如果我们在models里设计数据库时,已经设计好了一个类(就是数据库的表)之后想复用这个类的信息来作为表单的模型,那么很简单,同样是在models中的一个类
class Advertisement(models.Model): 
  #订单编号
  OrderID    =     models.ForeignKey(OrderInfo)
  #//广告标题#
  Title    =    models.CharField(max_length = 36) 
  #//广告内容#
  Content    =    models.CharField(max_length = 600)
注意,他的类型是models.Model,是做数据库ORM用的。

然后怎么关联呢?
需要导入一个新的类 (ModelForm)
from django.forms import ModelForm

class ContactForm(ModelForm):
   class Meta:
    model = Advertisement
    fields = ( 'Title', 'CustomerID')

这里的Advertisement就是之前那个ORM的模型。


第二步:OK,继续我们的表单,下一步需要做什么呢?开始在views.py里写对表单的调用吧.
def remark(request):


         if request.method ==  'POST': # 如果表单被提交
                form = ContactForm(request.POST) # 获取Post表单数据
                 if form.is_valid(): # 验证表单
                        return HttpResponseRedirect( '/') # 跳转
         else:
                form = ContactForm() #获得表单对象
                
        return render_to_response( 'message.html', {
                 'form': form,
        })

整个代码很简单,我就不过多的解释了。


第三步:我们知道django里任何访问都是通过urls.py来管理的。所以下面我们需要配置一个路径。

  (r '^message', 'iring.views.remark'),

第四步:最后应该是建立一个模板的时候了,因为我们最终是输出到html上的.注意views的remark函数最后一行
        return render_to_response( 'message.html', {
                 'form': form,
        })

就是讲当前的表单对象输出到message.html里,自动生成一个表单。
所以,先构建一个html.
这个html模板很简单,除去不必要的CSS,我只给出核心部分好啦。
   < form  action ="/message/"  method ="POST" >
    {% for field in form %}
       < div  class ="fieldWrapper" >
         {{ field.label_tag }}:{{ field }} 
         {{ field.errors }}
       </div>
    {% endfor %}
     < div  class ="fieldWrapper" > < p > < input  type ="submit"  value ="留言"  /> </p> </div>
   </form>

{% for field in form %}

{% endfor %}
用于对表单对象里的元素进行遍历,然后通过
{{ field.label_tag }}
{{ field }} 
{{ field.errors }}
这三个标签来输出,注意{{ field.errors }}默认情况下是不会输出的,只有当验证表单正确性时才会输出内容。

最终我们通过
http://youdjangourl/message来访问这个例子








  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 扫一扫,分享海报

©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值