首页>>后端>>Python->django官方手册怎么使用?

django官方手册怎么使用?

时间:2023-12-12 本站 点击:0

导读:很多朋友问到关于django官方手册怎么使用的相关问题,本文首席CTO笔记就来为大家做个详细解答,供大家参考,希望对大家有所帮助!一起来看看吧!

如何正确使用 Django Forms

1. Django Forms的强大之处

有些django项目并不直接呈现HTML, 二是以API框架的形式存在, 但你可能没有想到, 在这些API形式的django项目中也用到了django forms. django forms不仅仅是用来呈现HTML的, 他们最强的地方应该是他们的验证能力. 下面我们就介绍几种和Django forms结合使用的模式:

2. 模式一: ModelForm和默认验证

最简单的使用模式便是ModelForm和model中定义的默认验证方式的组合:

# myapp/views.py

from django.views.generic import CreateView, UpdateView

from braces.views import LoginRequiredMixin

from .models import Article

class ArticleCreateView(LoginRequiredMixin, CreateView):

model = Article

fields = ('title', 'slug', 'review_num')

class ArticleUpdateView(LoginRequiredMixin, UpdateView):

model = Article

fields = ('title', 'slug', 'review_num')

正如以上代码中看到的一样:

ArticleCreateView和ArticleUpdateView中设置model为Article

两个view都基于Article model自动生成了ModelForm

这些ModelForm的验证, 是基于Article model中定义的field转换而来的

3. 模式二, 在ModelForm中修改验证

在上面的例子中, 如果我们希望每篇article title的开头都是"new", 那么应该怎么做呢? 首先我们需要建立自定义的验证(validator):

# utils/validator.py

from django.core.exceptions import ValidationError

def validate_begins(value):

if not value.startswith(u'new'):

raise ValidationError(u'Must start with new')

可见, 在django中的验证程序就是不符合条件便抛出ValidationError的function, 为了方便重复使用, 我们将它们放在django app utils的validators.py中.

接下来, 我们可以在model中加入这些validator, 但为了今后的方便修改和维护, 我们更倾向于加入到ModelForm中:

# myapp/forms.py

from django import forms

from utils.validators import validate_begin

from .models import Article

class ArticleForm(forms.ModelForm):

dev __init__(self, *args, **kwargs):

super(ArticleForm, self).__init__(8args, **kwargs)

self.fields["title"].validators.append(validate_begin)

class Meta:

model = Article

Django的edit views(UpdateView和CreateView等)的默认行为是根据view中model属性, 自动创建ModelForm. 因此, 我们需要调用我们自己的Modelform来覆盖自动创建的:

# myapp/views.py

from django.views.generic import CreateView, UpdateView

from braces.views import LoginRequiredMixin

from .models import Article

from .forms import ArticleForm

class ArticleCreateView(LoginRequiredMixin, CreateView):

model = Article

fields = ('title', 'slug', 'review_num')

form_class = ArticleForm

class ArticleUpdateView(LoginRequiredMixin, UpdateView):

model = Article

fields = ('title', 'slug', 'review_num')

form_class = ArticleForm

4. 模式三, 使用form的clean()和clean_field()方法

如果我们希望验证form中的多个field, 或者验证涉及到已经存在之后的数据, 那么我们就需要用到form的clean()和clean_field()方法了. 以下代码检查密码长度是否大于7位, 并且password是否和password2相同:

# myapp/forms.py

from django import forms

class MyUserForm(forms.Form):

username = forms.CharField()

password = forms.CharField()

password2 = forms.CharField()

def clean_password(self):

password = self.cleaned_data['password']

if len(password) = 7:

raise forms.ValidationError("password insecure")

return password

def clean():

cleaned_data = super(MyUserForm, self).clean()

password = cleaned_data.get('password', '')

password2 = cleaned_data.get('password2', '')

if password != password2:

raise forms.ValidationError("passwords not match")

return cleaned_data

其中需要注意的是, clean()和clean_field()的最后必须返回验证完毕或修改后的值.

5. 模式四, 自定义ModelForm中的field

我们会经常遇到在form中需要修改默认的验证, 比如一个model中有许多非必填项, 但为了信息完整, 你希望这些field在填写时是必填的:

# myapp/models.py

from django.db import models

class MyUser(models.Model):

username = models.CharField(max_length=100)

password = models.CharField(max_length=100)

address = models.TextField(blank=True)

phone = models.CharField(max_length=100, blank=True)

为了达到以上要求, 你可能会通过直接增加field改写ModelForm:

# 请不要这么做

# myapp/forms.py

from django import forms

from .models import MyUser

class MyUserForm(forms.ModelForm):

# 请不要这么做

address = forms.CharField(required=True)

# 请不要这么做

phone = forms.CharField(required=True)

class Meta:

model = MyUser

请不要这么做, 因为这违反"不重复"的原则, 而且经过多次的拷贝粘贴, 代码会变得复杂难维护. 正确的方式应当是利用__init__():

# myapp/forms.py

from django import forms

from .models import MyUser

class MyUserForm(forms.ModelForm):

def __init__(self, *args, **kwarg):

super(MyUserForm, self).__init__(*args, **kwargs)

self.fields['address'].required = True

self.fields['phone'].required = True

class Meta:

model = MyUser

值得注意的是, Django forms也是Python类, 类可以继承和被继承, 也可以动态修改.

django models.SlugField 怎么使用

SlugField字段是将输入的内容中的空格都替换成‘-’之后保存

Django官方文档中关于SlugField的描述如下:

class SlugField([max_length=50, **options])

Slug 是一个新闻术语,通常是某些东西的短标签。一个slug只能包含字母、数字、下划线或者是连字符,通常用来作为短标签。通常它们是用来放在URL里的。

像CharField一样,你可以指定max_length(也请参阅该部分中的有关数据库可移植性的说明和max_length)。如果没有指定 max_length, Django将会默认长度为50。

SlugField字段的Field.db_index自动设置为True。

通常根据另一个值自动生成slug来填充到SlugField的值。你可以在admin中使用prepopulated_fields自动执行此操作。

可以重写save(),用slugfy方法转化数据后自动填充到SlugField中。简单示范如下

class test(models.Model):

    q = models.CharField(max_length=30)

    s = models.SlugField()

    def save(self, *args, **kwargs):

        self.s = slugify(self.q)

        super(test, self).save(*args, **kwargs)

一般多应用于URL正则表达式中的named group,作为参数在视图和URL之间传递

求django中文教程。

The Django Book

注意:Django book 2.0 的中文翻译已经开始,请访问! 这里进行的是Django book 1.0 的中文翻译,是django 0.96 版本,要适合django1.0和1.1请访问Django book 2.0的翻译,你也可以参与翻译,方法是通过点击右边颜色条上的深色块进入该段翻译, 如果你没有启用Javascript的话也可以通过点击右上角的翻译连接进行翻译。 翻译使用的文本格式是reStructuredText。左边颜色条的功能是评注。 (注:本页面不能使用这些功能,请在下面的章节页面使用这些功能。)

结语:以上就是首席CTO笔记为大家整理的关于django官方手册怎么使用的相关内容解答汇总了,希望对您有所帮助!如果解决了您的问题欢迎分享给更多关注此问题的朋友喔~


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/Python/28064.html