django如何捕获页面的值(2023年最新解答)

导读:本篇文章首席CTO笔记来给大家介绍有关django如何捕获页面的值的相关内容,希望对大家有所帮助,一起来看看吧。

请教django向 html页面传值的问题

有2种方法: 1,在模版中的html文件中嵌入含有这个函数的js文件或者直接加到html里面. 2,在js中通过ajax访问打开一个链接,比如/admin/url?key=value,那么在admin.py中的url方法中这样keyvlaue = request.GET.get(\'key\',None)来获取这个value

django 获取表单页面复选框的值 报错

class AddBookForm(forms.Form):

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

        ...

        self.fields[\'authors\'].choices = [(author.id,author.first_name + \" \" + author.last_name) for author in Author.objects.all()]

        self.fields[\'publisher\'].choices = [(\'\',\'-----------\')] + [(publisher.id,publisher.name) for publisher in Publisher.objects.all()]

        ...

form里这两行有问题,这行如果你想重新赋值的话应该给一个queryset,而不是列表。如果你想测试一下的话可以先把这行注释掉,然后你在提交看看表单验证是否能通过。如果通过了那确定问题就是这里了。我想我应该不会错。。。

求助django 实现前端页面检索功能的代码

设我们的 django 博客应用有如下的文章模型:

blog/models.pyclass Post(models.Model):

# 标题

title = models.CharField(max_length=70)

# 正文

body = models.TextField()

# 其他属性

def __str__(self):

return self.title

先看到第 1 步,用户在搜索框输入搜索关键词,因此我们要在博客上为用户提供一个搜索表单,html 表单代码大概像这样:

form method=\"get\" action=\"/search/\"

{% csrf_token %} input type=\"search\" placeholder=\"搜索\" required

button type=\"submit\"搜索/button/form

特别注意在 form 标签下有一个 {% csrf_token %},这是 django 用来防御跨站请求伪造(CSRF)攻击的机制。如果不知道什么是 CSRF 的话也没有关系,只要记住在使用 django 时,前端的表单代码里一定要加上 {% csrf_token %}。

用户输入了搜索关键词并点击了搜索按钮后,数据就被发送给了 django 后台服务器。表单的 action 属性的值为 /search/,表明用户提交的结果将被发送给 /search/ 这个 URL。我们为这个 URL 绑定一个 django 视图函数,在这个视图函数里完成前面第 2 步提到的过程。假设我们把视图函数的代码写在 blog/views.py 里:

blog/views.pydef search(request):

q = request.GET.get(\'q\')

error_msg = \'\'

if not q:

error_msg = \'请输入关键词\'

return render(request, \'blog/errors.html\', {\'error_msg\': error_msg})

post_list = Post.objects.filter(title__icontains=q)

return render(request, \'blog/results.html\', {\'error_msg\': error_msg,

\'post_list\': post_list})

首先我们使用 request.GET.get(\'q\') 获取到用户提交的搜索关键词。用户通过表单提交的数据 django 为我们保存在 request.GET 里,这是一个类似于 Python 字典的对象,所以我们使用 get 方法从字典里取出键 q 对应的值,即用户的搜索关键词。这里字典的键之所以叫 q 是因为我们的表单中搜索框 input 的 name 属性的值是 q,如果修改了 name 属性的值,那么这个键的名称也要相应修改。

接下来我们做了一个小小的校验,如果用户没有输入搜索关键词而提交了表单,我们就无需执行查询,而是渲染一个错误页面提示用户请输入关键词。

如果用户输入了搜索关键词,我们就通过 filter 方法从数据库里过滤出符合条件的所有文章。这里的过滤条件是 title__icontains=q,即 title 中包含(contains)关键字 q,前缀 i 表示不区分大小写。这里 icontains 是查询表达式(Field lookups),其用法是在模型需要筛选的属性后面跟上两个下划线。django 内置了很多查询表达式,建议过一遍 django 官方留个印象,了解每个表达式的作用,以后碰到相关的需求就可以快速定位到文档查询其用途:Field lookups

接下来就是渲染搜索结果页面,显示符合搜索条件的文章列表,下面是一个模板的简单示例:

results.html

{% if error_msg %} p{{ error_msg }}/p{% endif %}

{% for post in post_list %} div

在这里显示文章的相应信息 /div{% empty %} div class=\"no-post\"

没有搜索到符合条件的文章 /div{% endfor %}

有了视图函数后记得把视图函数映射到相应了 URL,前面我们表单数据提交的 URL 为 /search/,因此将视图函数 search 绑定到该 URL 上。

blog/urls.pyurlpatterns = [

# 其他 url 配置

url(r\'^search/$\', views.search, name=\'search\'),]

大功告成!

django视图中怎么把从前端获取的user作为全局变量

有时候,我们需要Templates模板页面可以使用一些变量。这些变量我们在views.py响应时没有返回设置的变量。例如,如下代码:

#coding:utf-8

from django.shortcuts import render

def index(request):

context = {}

context[\'title\'] = \'测试标题\'

return render(request, \'index.html\', context)

上面是某个views.py的方法之一。它将渲染index.html模版(Template)页面,并返回context字典。该字典是传入变量信息给前端页面。对应的index.html如下:

 

html

head/head

body

h3{{title}}/h3

p是否登录:{{request.user.is_authenticated}}/p

/body

/html

响应结果除了有title变量值之外,还有是否登录信息。该登录信息来自request变量,问题是上面views.py中返回结果的context中没有写入request变量。而模版也没却有可以获取该变量。

这个当时不是无中生有,我一步一步剖析给大家看。原理讲明白之后,就自然懂得如何设置模版(Templates)的全局变量或者叫默认变量。

render方法是render_to_response方法的简写方式。上面的views.py代码相当于如下:

 

#coding:utf-8

from django.shortcuts import render_to_response

from django.template import RequestContext

def index(request):

context = {}

context[\'title\'] = \'测试标题\'

return render_to_response(\'index.html\', context, RequestContext(request))

如果去掉render_to_response的第三个参数,即RequestContext(request)部分。

渲染index.html模版页面就无法得到{{request.user.is_authenticated}}的值,即没有传递request变量给前端页面。很明显RequestContext很关键。

有关RequestContext的内容可以从Django官方文档查得。

该类实例化时会解析settings中的Templates设置中的context_processors配置。新建Django项目settings.py文件中默认的Templates设置如下:

 

TEMPLATES = [

{

\'BACKEND\': \'django.template.backends.django.DjangoTemplates\',

\'DIRS\': [],

\'APP_DIRS\': True,

\'OPTIONS\': {

\'context_processors\': [

\'django.template.context_processors.debug\',

\'django.template.context_processors.request\',

\'django.contrib.auth.context_processors.auth\',

\'django.contrib.messages.context_processors.messages\',

],

},

},

]

大家可发现context_processors有一系列设置,其中根据django.template.context_processors.request的路径找到Django的相关源码。

Django安装在Python的安装目录下Lib/site-packages/目录中,找到django/template/context_processors.py文件,打开可看到request方法:

 

def request(request):

return {\'request\': request}

该方法返回一个字典,key为request,value为request对象。很明显,render中的request对象就是通过加载settings中的context_processors列表方法得到字典项。

我们也可以采用这种方法,给Django项目设置全局的模版变量。例如,我的Django名称为myproject,在myproject/myproject目录中创建一个contexts.py文件,代码如下:

 

#coding:utf-8

from django.conf import settings

# 得到语言设置

def lang(request):

return {\'lang\': settings.LANGUAGE_CODE}

该文件的方法需要request参数,最后需要返回一个字典即可。

再打开settings.py文件,在Templates中添加刚才写的方法引用:

 

TEMPLATES = [

{

\'BACKEND\': \'django.template.backends.django.DjangoTemplates\',

\'DIRS\': [],

\'APP_DIRS\': True,

\'OPTIONS\': {

\'context_processors\': [

\'django.template.context_processors.debug\',

\'django.template.context_processors.request\',

\'django.contrib.auth.context_processors.auth\',

\'django.contrib.messages.context_processors.messages\',

# 自定义模版全局变量(默认变量)

\'myproject.contexts.lang\',

],

},

},

]

添加模版全局变量之后,我们可以在任意位置渲染模版页面无需再手动写相关代码即可使用该变量。

django如何捕获页面的值(2023年最新解答)  第1张

结语:以上就是首席CTO笔记为大家整理的关于django如何捕获页面的值的全部内容了,感谢您花时间阅读本站内容,希望对您有所帮助,更多关于django如何捕获页面的值的相关内容别忘了在本站进行查找喔。

以上内容为新媒号(sinv.com.cn)为大家提供!新媒号,坚持更新大家所需的互联网后端知识。希望您喜欢!

版权申明:新媒号所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流,不声明或保证其内容的正确性,如发现本站有涉嫌抄袭侵权/违法违规的内容。请发送邮件至 k2#88.com(替换@) 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023-09-23 13:14
下一篇 2023-09-23 13:14

相关推荐

发表回复

登录后才能评论