Django开发web站点步骤

简介:

1、创建Django工程

1
django-admin startproject 工程名


2、创建App

1
2
cd  工程名
  python manage.py startapp cmdb


3、静态文件配置

编辑 project.settings.py,追加以下内容

1
2
3
STATICFILES_DIRS = (
     os.path. join (BASE_DIR,  "static" ),
)


4、模板路径配置

1
DIRS ==> (os.path. join (BASE_DIR,  'templates' ),)


5、settings中,注释 csrf

1
2
3
MIDDLEWARE_CLASSES = (
     #'django.middleware.csrf.CsrfViewMiddleware',
)

6、定义路由规则,在url.py中定义用户访问的url由哪个函数来处理请求

1
2
url.py
     "login"   --> 函数名


7、定义视图函数,在views.py中定义函数

1
2
3
4
5
6
7
8
def func(reuest):
     # request.method GET/POST
     # http://127.0.0.1:8000/home?nid=123&name=bob
     # request.GET.get('',None)  #获取请求发来的数据
     # request.POST.get('',None)
     # return HttpResponse("字符串")
     # return Render(request, 'HTML模板路径',{"user_list": USER_LIST})
     # return redirect('只能填URL,例如:/home')


8、模板渲染

Django特殊的模板语言,例如:

--变量名取值--

在views.py中定义好变量和对应的值,在template的html页面中通过` var_name `的方式来取值

1
2
3
4
5
6
7
8
9
10
def func(request):
    return  render(request, "index.html" ,{ 'current_user' "bob" })
 
index.html
 
<html>
<body>
     <div>{{ current_user }}< /div >
< /body >
< /html >


--For循环取值--

在views.py中定义好列表和值,在template的html页面中通过{{ for循环 }}的方式来取值

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def func(request):
     return  render(request, "index.html" ,{
     'current_user' "bob" ,
     'user_list' :[ 'bob' , 'aaa' , 'bbb' ]})
 
index.html
<html>
<body>
     <div>{{ current_user }}< /div >
     <ul>
     {%  for  row  in  user_list %}
         <li>{{ row }}< /li >
     <% endfor %>
     < /ul >
< /body >
< /html >


--索引取值--

在views.py中定义好字典和值,在template的html页面中通过` var_name`.`key `的方式来取值

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
def func(request):
     return  render(request, "index.html" ,{
         'current_user' "bob"
         'user_list' : [ 'bob' , 'aaa' , 'bbb' ],
         'user_dict' : [ 'k1' 'v1' 'k2' 'v2' ]
         })
         
index.html
 
<html>
<body>
     <div>{{ current_user }}< /div >
     <a>{{ user_list.1 }}< /a >   // 对于列表直接用索引取值
     <a>{{ user_dict.k1 }}< /a // 对于字典,要用key取值
     <a>{{ user_dict.k2 }}< /a >
< /body >
< /html >


--循环字典--

模板语法除了而已循环列表外,也可以循环字典,用法和python基本一样,只不过循环时,不要加括号()


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
USER_DICT = {
     'K1' 'V1' ,
     'K2' 'V2' ,
     'K3' 'V3' ,
     'K4' 'V4'
}
 
 
例1、循环key
{%  for  in  USER_DICT.keys %}
     <li>{{ k }}< /li >
{% endfor %}
 
 
例2、循环键值对
{%  for  item  in  USER_DICT.items %}
     <li>{{ item }}< /li >
{% endfor %}
 
例3、循环values
{%  for  v  in  USER_DICT.values %}
     <li>{{  v  }}< /li >
{% endfor %}
 
例4、循环values
{%  for  k, v  in  USER_DICT.items %}
     <li>{{ k }}-{{  v  }}< /li >
{% endfor %}



--条件取值--

{% if %}

    {% if %}

    {% endif %}

    {% else%}

{% else %}

{% endif %}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
def func(request):
     return  render(request, "index.html" ,{
         'current_user' "bob"
         'age' : 18,
         'user_list' : [ 'bob' , 'aaa' , 'bbb' ],
         'user_dict' : [ 'k1' 'v1' 'k2' 'v2' ]
         })
         
index.html
 
<html>
<body>
 
     <div>{{ current_user }}< /div >
     <a>{{ user_list.1 }}< /a >   // 对于列表直接用索引取值
     <a>{{ user_dict.k1 }}< /a // 对于字典,要用key取值
     <a>{{ user_dict.k2 }}< /a >
     {%  if  age %}
     <a>有年龄< /a >
         {%  if  age > 16 %}
             <a>老男人< /a >
         {%  else  %}
             <a>小鲜肉< /a >
         {% endif %}
     {%  else  %}
         <a>无年龄< /a >
     {% endif %}
< /body >
< /html >


模板的工作流程:

  • 1、当用户请求通过url发送请求后,django路由将请求交给视图函数,

  • 2、然后视图函数会先去取模板,

  • 3、将模板中有` current_user `这样的变量与视图中定义的值进行渲染,渲染后将模板内容转换成字符串

  • 4、将生成后字符串整体返回给用户



过滤器

模板过滤器是变量显示前转换它们的值的方式,看起来像下面这样

1
{{ name|lower }}

这将显示通过lower过滤器过滤后` name `变量的值,它将文本转换成小写
使用(|)管道来申请一个过滤器


过滤器可以串成链,即一个过滤器的结果可以传向下一个,下面是escape文本内容然后把换行转换成p标签的习惯用法

1
{{ my_text|escape|linebreaks }}











本文转自 曾哥最爱 51CTO博客,原文链接:http://blog.51cto.com/zengestudy/1931369,如需转载请自行联系原作者

目录
相关文章
|
6月前
|
算法 Java Go
【GoGin】(1)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收
gin 框架中采用的路优酷是基于httprouter做的是一个高性能的 HTTP 请求路由器,适用于 Go 语言。它的设计目标是提供高效的路由匹配和低内存占用,特别适合需要高性能和简单路由的应用场景。
554 4
|
10月前
|
缓存 JavaScript 前端开发
鸿蒙5开发宝藏案例分享---Web开发优化案例分享
本文深入解读鸿蒙官方文档中的 `ArkWeb` 性能优化技巧,从预启动进程到预渲染,涵盖预下载、预连接、预取POST等八大优化策略。通过代码示例详解如何提升Web页面加载速度,助你打造流畅的HarmonyOS应用体验。内容实用,按需选用,让H5页面快到飞起!
|
10月前
|
JavaScript 前端开发 API
鸿蒙5开发宝藏案例分享---Web加载时延优化解析
本文深入解析了鸿蒙开发中Web加载完成时延的优化技巧,结合官方案例与实际代码,助你提升性能。核心内容包括:使用DevEco Profiler和DevTools定位瓶颈、四大优化方向(资源合并、接口预取、图片懒加载、任务拆解)及高频手段总结。同时提供性能优化黄金准则,如首屏资源控制在300KB内、关键接口响应≤200ms等,帮助开发者实现丝般流畅体验。
|
前端开发 JavaScript Shell
鸿蒙5开发宝藏案例分享---Web页面内点击响应时延分析
本文为鸿蒙开发者整理了Web性能优化的实战案例解析,结合官方文档深度扩展。内容涵盖点击响应时延核心指标(≤100ms)、性能分析工具链(如DevTools时间线、ArkUI Trace抓取)以及高频优化场景,包括递归函数优化、网络请求阻塞解决方案和setTimeout滥用问题等。同时提供进阶技巧,如首帧加速、透明动画陷阱规避及Web组件初始化加速,并通过优化前后Trace对比展示成果。最后总结了快速定位问题的方法与开发建议,助力开发者提升Web应用性能。
|
10月前
|
JSON 开发框架 自然语言处理
【HarmonyOS Next之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(三)
本文主要介绍了应用开发中的三大核心内容:生命周期管理、资源限定与访问以及多语言支持。在生命周期部分,详细说明了应用和页面的生命周期函数及其触发时机,帮助开发者更好地掌控应用状态变化。资源限定与访问章节,则聚焦于资源限定词的定义、命名规则及匹配逻辑,并阐述了如何通过 `$r` 引用 JS 模块内的资源。最后,多语言支持部分讲解了如何通过 JSON 文件定义多语言资源,使用 `$t` 和 `$tc` 方法实现简单格式化与单复数格式化,为全球化应用提供便利。
341 104
|
9月前
|
存储 前端开发 应用服务中间件
Django 实战:静态文件与媒体文件从开发配置到生产部署
Django项目中,静态文件(Static Files)和媒体文件(Media Files)是两类不同用途的文件。本文详细介绍了它们的区别、配置方法以及在开发与生产环境中的处理方式,并结合用户头像上传功能进行实战演示,最后讲解了如何通过Nginx或OpenResty部署静态与媒体文件服务。
447 1
|
10月前
|
JavaScript 前端开发 API
【HarmonyOS Next之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(二)
本文介绍了HarmonyOS应用开发中的HML、CSS和JS语法。HML作为标记语言,支持数据绑定、事件处理、列表渲染等功能;CSS用于样式定义,涵盖尺寸单位、样式导入、选择器及伪类等特性;JS实现业务逻辑,包括ES6语法支持、对象属性、数据方法及事件处理。通过具体代码示例,详细解析了页面构建与交互的实现方式,为开发者提供全面的技术指导。
365 104
|
10月前
|
开发框架 编解码 JavaScript
【HarmonyOS Next之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(一)
该文档详细介绍了一个兼容JS的类Web开发范式的方舟开发框架,涵盖概述、文件组织、js标签配置及app.js等内容。框架采用HML、CSS、JavaScript三段式开发方式,支持单向数据绑定,适合中小型应用开发。文件组织部分说明了目录结构、访问规则和媒体文件格式;js标签配置包括实例名称、页面路由和窗口样式信息;app.js则描述了应用生命周期与对象管理。整体内容旨在帮助开发者快速构建基于方舟框架的应用程序。
378 102
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。
1009 157
下一篇
开通oss服务