简介:许多朋友问有关Django如何定制管理界面的问题。本文的首席CTO笔记开始为您的参考做出详细的答案。我希望这对每个人都会有所帮助!让我们一起看看!
Django的背景扩展具有扩展模型和一个扩展模型字段(字段),但我仍然最喜欢这种扩展方法(Django的官方文档,非常适合自定义):
从:
该原理非常简单,也就是说,在url.py上添加URL配置以覆盖背景的默认URL处理,然后您可以按照需要编写自己的视图
显然,管理接口对于数据编辑非常有用(想象)。如果它用于完成某些数据的输入工作,则管理接口确实无人看管。我们猜测,本书中的大多数读者都有大量数据输入任务。
Django管理界面特别注意那些没有技术背景的人使用数据输入;这也是发展此功能的目的。在Django的最初开发土地报纸,开发了典型的在线市政供水质量报告系统,需求如下:
负责此主题的记者与开发人员结识并提交了现有数据。
开发人员设计了围绕数据的模型,并为记者开发管理接口。
当记者将数据输入Django时,程序员可以专注于公共访问界面的开发(最有趣的部分!)。
换句话说,Django管理接口的主要目的是同时促进内容编辑器和程序员。
当然,除了明显的数据输入任务外,我们发现管理接口在其他情况下非常有用。
crqrwv a href = https://www.shouxicto.com/article/“” xwyekefymefu/a,[url =] eycmfqtvgmvb [/url],[link =]
管理数据:很少有实际数据输入与这样的站点关联,因为大多数数据来自自动生成的来源。但是,当获得的数据错误造成麻烦时,它可以轻松找到并修改错误数据以帮助问题解决。。
如果没有或只是自定义,Django管理界面就可以处理大多数常见情况。但是,正是由于Django管理界面可以处理这种常见情况,它无法处理其他编辑模型。
4yqjmu a href = https://www.shouxicto.com/article/“” kdqfnmmekszw/a,[url =] zusybryiqeir [/url],[link =]
管理
bmufnt a href = https://www.shouxicto.com/article/“” ifhkpydljkaf/a,[url =] mqitqhmcazco [/url],[link =] qcmerxzxnmhj [/link],
受信任的用户编辑结构化内容。
是的,这很简单,但是这个简单是建立在一堆假设上的。django管理界面的所有设计概念都遵循这些假设,因此让我们理解这些后续部分中术语的含义。
受信任的用户
管理界面的设计是由像您这样的开发人员使用的人。在这里,不仅仅是通过身份验证的人;据说Django假设内容编辑器只能执行内容编辑器的工作。
另一方面,这意味着,如果您信任用户,他们可以在不获得许可证的情况下编辑内容,并且没有人需要允许其编辑行为。另一个含义是,尽管身份验证系统具有强大的功能,但它不支持在本书中撰写时,访问对象 - 级基础的限制。如果您允许某人编辑新闻报告,则必须确保未经许可用户不会编辑其他人的报告。
编辑
Django管理界面的主要目的是让用户编辑数据。乍一看,这很明显,但是如果您考虑一下,它将变得有些难以捉摸且非凡。
例如,尽管管理接口非常方便检查数据(如今所讨论),但这不是其最初的意图。例如,我们在第12章中提到,它缺乏视图允许允许。在管理接口中,还可以执行编辑器。
还需要注意的是,这是缺乏远程呼叫工作流程。如果特定任务包括一系列步骤,则没有机制确保可以按特定顺序完成这些步骤。DJANGOMANACORAME接口专注于编辑,不关心改变周围活动。此逃避工作流程也来自信任原则:管理接口的设计概念是工作流是一件事情,并且不需要在代码中实现。
最后,应该注意的是,管理接口中缺乏聚合。换句话说,它不支持显示总数,平均值等的内容。再次,管理界面仅用于编辑 - 期望您通过定义视图来完成所有其他任务。
结构化内容
30cen9 a href = https://www.shouxicto.com/article/“” bxyzitjhvwis/a,[url =] ylhgcrwsnuue [/url],[link =] mecoeqQxpail [/link],
这里
现在可以肯定的是,Django的管理接口并不打算成为每个人的通用工具。相反,我们选择专注于做一件事情并完成它。
sapqz9 a href = https://www.shouxicto.com/article/“” fmvbpdngtcts/a,[url =] tvwreqwomvco [/url],[link =]
必须记住的是,尽管管理界面很复杂,但它总是一个应用程序。只要有足够的时间,任何Django开发人员都可以做所有事情。将来的管理界面。这个新界面具有一系列不同的先决条件,并且工作方法完全不同。
最后,应该指出的是,在撰写本文时,Django开发人员正在进行新的管理接口开发工作,该工作将提供更自定义的灵活性。当您阅读本文时,这些新功能可能已输入真正的Django版本。
定制管理模板
lryxwt a href = https://www.shouxicto.com/article/“” uokhfgxirpcl/a,[url =] wqhpuiouinaf [/url],[link =] fatpucympci [/link],
现在,让我们看看如何快速自定义管理管理接口的外观。第6章讨论了一些最常见的任务:修改商标(对于那些讨厌蓝色头发的老板)或提供自定义表格。
进一步的目标通常包括,更改模板中的一些特殊项目。每个管理员的视图,包括修改列表,编辑表格,删除确认页面和历史视图。有一个与之相关联的模板可以在许多方面覆盖。
首先,您可以在全局情况下覆盖模板。Admin视图使用标准模板加载机制来查找模板。因此,如果您在模板目录中创建新模板,Django将自动加载它。图17中列出了图模板。-1。
fd2cvv a href = https://www.shouxicto.com/article/“” fphafdvvvmhea/a,[url =] mompqgnztmob [/url],[link =] oamzxjphpsxv [/link],
在大多数情况下,您可能只想修改单独的对象或应用程序,而不是修改整体设置。因此,每个管理员视图总是找到与模型或应用程序相关的模板。查找模板的顺序如下:
admin/app_label/object_name/template.html
jrmal2 a href = https://www.shouxicto.com/article/“” kqqeldaxlpkep/a,[url =] ihzkjznjrsqj [/url],[link =]
admin/template.html
例如,在书籍应用程序中,书籍模块添加/编辑表单的视图将按以下顺序找到模板:
管理/书籍/书籍/thex_form.html
admin/books/change_form.html
admin/change_form.html
自定义模型模板
在大多数情况下,您想使用第一个模板来创建特定的模型模板。从基础上讲,最好的方法是将信息添加到基础模板中定义的块和块。
例如,我们想在书页面的顶部添加一些帮助文本。这可能是图17-1所示的形式。
图17-1。定制管理编辑表格。
这很容易做到:只需构建Admin/BookStore/book/drack_form.html模板,然后输入以下代码:
{%扩展“ admin/change_form.html”%}
{%block form_top%}
pinsert有意义的帮助消息在这里.https://www.shouxicto.com/p
{%endBlock%}
mgrlx4 a href = https://www.shouxicto.com/article/“” omnhyzkldddtt/a,[url =] ydlrolrelntzkskj [/url],[link =]
自定义JavaScript
这些自定义模型模板的常见用途包括将自定义JavaScript代码添加到管理页面,以实现一些特殊的视图对象或客户端行为。
幸运的是,这可能很容易。每个管理模板定义{%block extrahead%},您可以在head元素中添加新内容。例如,如果要将jquery()添加到管理员历史记录中,则可以做到这一点:
{%扩展“ admin/object_history.html”%}
{%阻止extrahead%}
脚本src =“ https://www.shouxicto.com/article/” type =“ text/javascript”/脚本
脚本类型=“ text/javascript”
//代码在这里实际使用jQuery ...
/脚本
{%endBlock%}
评论
我们不知道为什么您需要将jQuery放入历史页面,但是可以在任何模板中使用此示例。
tyy7is a href = https://www.shouxicto.com/article/“” hpswriedwzmw/a,[url =] bvkzckktnoefm [/url],[link =]
创建自定义管理视图
现在,想要在Django的管理员 - 调节界面中添加自定义行为的人可能会感到有些奇怪。我们在这里谈论的是如何更改管理员管理界面的外观。他们都在喊叫:我们如何更改管理管理界面的内部工作机制。
首先要提到的是这并不令人惊讶。Admin的管理界面没有做任何特别的事情。就像其他视图一样,仅处理数据。
确实,这里有很多代码。它必须处理各种操作,现场类型和设置以显示模型的行为。当您注意到管理员界面只是一系列视图(视图)时,增加自定义管理,视图变得易于理解。
例如,让我们将发布者报告的视图添加到第6章中的第6本书中。创建了管理视图列表,以显示出发布者划分的书籍列表,这是您要建立的自定义管理员报告视图的非常典型的示例。
首先,在我们的urlconf.sert中连接视图以下行:
(r'^admin/books/report/$','mysite.books.admin_views.report'),
在将此行添加到此管理视图之前,原始URLCONF应该是这样的:
来自django.conf.urls.defaults导入 *
urlpatterns =模式('',,
(r'^admin/bookstore/report/$','bookstore.admin_views.report'),
(r'^admin/',inderude('django.contrib.admin.urls'),),),),
治愈
您为什么要尝试在管理内容之前放置自定义的尝试?回想一下Django处理订单的URL匹配。在管理内容与内容匹配后,如果我们扭转了这些行的顺序,Django会找到一个内部管理视图,以了解匹配公式,并将尝试在“书籍”应用程序中输入报告模型,然后输入列表,但这不存在。
现在我们开始写一个视图。简单起见,我们只将所有书籍加载到上下文中,然后让模板使用{%regroup%}标签来处理组操作。创建book/admin_views.py文件并写下以下内容:
来自mysite.books.models导入书籍
来自django.template导入requestContext
来自django.shortcuts导入render_to_response
来自django.contrib.admin.views.decorators导入suffer_member_required
DEF报告(请求):
返回render_to_response(
“ admin/books/report.html”,
{'book_list':book.objects.all()},
requestContext(请求,{}),
治愈
报告= Staff_Member_Required(报告)
因为我们将小组操作留在模板上,所以视图非常简单。但是,有几个微妙的细节值得我们理解。
我们在django.contrib.admin.views.decorators中使用了Staff_Member_Required修改器。装饰师类似于第12章中讨论的login_required,但它还检查了用户是否指定为内部人员来确定他是否允许他访问管理层界面。
修饰符保护所有内容的管理视图,并使身份验证逻辑匹配管理接口的其他部分。
我们分析了管理下的模板。尽管并非严格要求这样做,但这是将所有管理模板放入管理员目录中的好方法。我们还将应用程序的所有模板都放在名为书名的目录中,也是最佳实践。
我们使用requestContext作为render_to_response的第三个参数(````context_instance“''')。这确保模板可以访问当前用户的信息。
请参阅第10章以了解有关RequestContext的更多信息。
最后,我们为此视图制作模板。我们将扩展构建的-in管理模板,以使视图显然成为管理接口的一部分。
{%扩展“ admin/base_site.html”%}
{%块标题%} publicsher {%endBlock%}的书籍列表
{%阻止内容%}
div ID =“ content-mail”
公共书籍的h1list:/h1
{%regroup book_list |dictsort:发布者的“ publisher.name”为books_by_publisher%}
{books_by_publisher%的发布者%}
H3 {Publisher.grouper}}/H3
Ul
{for in public in public.list |distsort:“ title”%}
li {book}}/li
{%endfor%}
/ul
{%endfor%}
/div
{%endBlock%}
通过扩展admin/base_site.html,我们无需付出任何努力即可出现Django管理接口。图17-2 i显示了这样的最终结果。
图17-2。出版商分类的书籍管理视图
使用此技术,您可以将梦想中的任何内容添加到管理界面。需要记住的是,这些称为自定义的管理视图实际上只是普通的Django视图。您可以使用本书其他部分中学到的技术来制作满足您需求的复杂管理界面。
遮盖终点
有时,默认管理视图无法完成某个工作。您可以轻松地放置自定义视图;您只需要用自己的URL覆盖构建的管理视图,换句话说,如果您的视图出现在URLConf中的默认管理视图中,则您的视图将替换默认视图并被调用。
例如,我们可以使用允许用户简单地输入ISBN替换构建的书籍创建视图的窗口。然后,我们可以查询本书的信息并自动创建对象。
此视图的代码作为练习留给读者。重要的部分是该URLCONF代码被打破:
;
如果此代码片段在管理URL之前出现在URLConf中,则add_by_isbn视图将完全替换标准管理视图。
这样,我们可以替换删除确认页面的任何部分,编辑页面或管理接口。
最后一个问题(Web网页个人开发的软件和配置基础)已详细介绍了基于Django+MySQL+Pycharm的Web开发的基础架构开发。本期将遵循作者编写第一个网页。他本人以及与作者同一局域网的其他用户也可以访问。
首先输入python manage.py startapp myfamilyweb(指示创建自己的网页项),如图1所示。
生成的myFamilyWeb中目录结构中的含义如下:
外层的_init_.py文件标识MyFamilyWeb是一个Python软件包。
Admin.py用于将模型定义注册到管理背景,这是Django Admin应用程序的配置文件。
apps.py用于应用程序本身的配置。
迁移目录用于将模型的定义和修改存储在模型文件中。
迁移/_init_.py文件标识迁移是一个Python软件包。
Model.py用于定义应用程序中所需的数据表。
tests.py文件用于编写当前应用程序的单元测试。
views.py文件用于编写应用程序视图。
上述介绍是MyFamilyWeb应用程序的所有内容。将来需要做的是填充相应的服务逻辑以提供服务。如果这是开始,您将发现无法如图2所示访问它。
如果要访问第一个网页(MyFamilyWeb),第一步是设置路由并添加一个函数以访问views.py(图3-图6)。
配置模板和HTML(图7位数13)
该配置已编写了第一个和最简单的网页来启动服务器。记录(图14)
在开发人员的计算机上访问浏览器(图15)
(配置防火墙端口)(图16)
设置以允许多个主机访问(图17)
输入ipconfig到终端
输入IPv4地址:192.168.0.102(图18)
python manage.py runserver 0.0.0.0:8000(启动时添加了0.0.0.0.0:8000)。
然后,本地网络中的其他计算机可以在浏览器中访问您的IP地址(此URL只能由同一局部网络的主机访问)
之后,我去学习如何编写HTML文件。
只需在安装目录中找到它,基本上是相同的
(1)初始接口
(2)查找base_site.html以修改名称
(1)查找样式文件
(2)编辑base.css
(1)登录接口
(2)背景接口
风俗。
Django正式有一个非常详细的管理员自定义文档
如果英语不好,我建议Django免费学习网站。Liu Jiang的Django教程非常好。
在您的apps.py方法中,您添加了一个if语句,如果用户
结论:以上是首席CTO的所有内容都注明了Django如何定制管理界面。感谢您阅读本网站的内容。我希望这对您有帮助。有关Django如何自定义管理接口的相关内容的更多信息,请在此站点上找到它。