django的环境配置和view的使用-创新互联

这篇文章主要介绍了django的环境配置和view的使用 ,具有一定借鉴价值,需要的朋友可以参考下。步骤简单适合新手,希望你能收获更多。下面是配置和使用的步骤内容。

10多年的荥经网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销的优势是能够根据用户设备显示端的尺寸不同,自动调整荥经建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联公司从事“荥经网站设计”,“荥经网站推广”以来,每个客户项目都认真落实执行。

一 基本环境

1 环境处理

mkdir  djanad cd djanad/ pyenv  virtualenv 3.6.5  djanad pyenv  local  djanad

结果如下

django的环境配置和view的使用

2  创建django和基本配置

 pip install  django==2.1
django-admin startproject  demo . django-admin  startapp  app

结果如下

django的环境配置和view的使用

数据库配置如下

django的环境配置和view的使用

基本时区和mysql配置及相关时区配置请看django基础

启动结果如下

django的环境配置和view的使用

二  view基本使用

1  view中使用模板

1  概述

django内置了自己的模板引擎,和jinjia 很像,使用简单

使用 Template 进行定义模板,使用Context 将数据导入到该模板中,其导入默认使用字典

django的环境配置和view的使用

2 环境准备

1 创建models

django 默认会去到app_name/templates下寻找模板,这是settings中的默认设置,默认会去app_name/static找那个寻找静态文件(css,js,jpg,html)等


在  app/models.py 中创建数据库表模板,具体配置如下:

from django.db import models # Create your models here. # 问题 class Question(models.Model):    question_text = models.CharField(max_length=200)    pub_date = models.DateTimeField('date published')    def __str__(self):      return self.question_text # 选择 # 配置选择为问题的外键,并配置选择的内容和选择的起始值 class Choice(models.Model):    question = models.ForeignKey(Question, on_delete=Question)    choice_text = models.CharField(max_length=200)    votes = models.IntegerField(default=0)    def __str__(self):      return self.choice_text
2 执行生成迁移文件和迁移并查看
 python manage.py  makemigrations  python manage.py  migrate

结果如下

django的环境配置和view的使用

3 添加数据进入表中

创建后台登陆用户,设置用户名为admin,密码为admin@123

django的环境配置和view的使用

4 将model中的模型添加进入django admin 后台管理界面

app/admin.py中添加

# Register your models here. from django.contrib import admin from .models import Question, Choice # Register your models here. class ChoiceInline(admin.TabularInline):    model = Choice    extra = 3 class QuestionAdmin(admin.ModelAdmin):    fieldsets = [      (None, {'fields': ['question_text']}),      ('Date information', {'fields': ['pub_date'], 'classes': ['collapse']}),    ]    inlines = [ChoiceInline]    list_display = ('question_text', 'pub_date') admin.site.register(Choice) admin.site.register(Question, QuestionAdmin)

url  :  localhost:port/admin/

5 登陆后台并添加数据如下

django的环境配置和view的使用

django的环境配置和view的使用

6 配置静态文件

demo/setting.py 中配置添加

STATICFILES_DIRS = [    os.path.join(BASE_DIR, 'static') ]

项目中创建static 并上传图片django.jpg

django的环境配置和view的使用

7  配置 url

demo/urls.py中配置如下

from django.conf.urls import url, include from django.contrib import admin urlpatterns = [    url(r'^admin/', admin.site.urls),    url(r'^app/', include("app.urls",namespace="app")),  #此处配置名称空间,用于处理后面的翻转 ]
8  app中创建  urls.py 文件,内容如下
from django.conf.urls import url, include from . import views urlpatterns = [    url(r'^index/$', views.index, name="index"), # name 指定名称, ]

django的环境配置和view的使用

3 view 使用

1 在view中直接嵌入模板,结果如下
from django.shortcuts import render from django.template import Template, Context from . import models from django.http import HttpResponse # Create your views here. def index(request):    lastes_question_list = models.Question.objects.order_by('-pub_date')[:5]    template = Template("""    <img  src="/static/django.jpg">    {%  if lastes_question_list %}    <ul>    {% for question  in  lastes_question_list %}    <li>  <a  href="/app/ {{question.id}}/"> {{ question.question_text }} </a> </li>    {% endfor %}    </ul>    {% endif %}    """)    context = Context({"lastes_question_list": lastes_question_list})    return HttpResponse(template.render(context))

访问配置,结果如下

django的环境配置和view的使用

2 使用html 模板如下

django的环境配置和view的使用

index 代码如下

<!DOCTYPE html> <html> <head>    <meta charset="UTF-8">    <title>测试数据</title> </head> <body> <img src="/static/django.jpg"> {% if lastes_question_list %} <ul>    {% for question in lastes_question_list %}    <li>      <a href="/app/{{question.id}}/"> {{question.question_text}} </a>    </li>    {% endfor %} </ul> {% endif%} </body> </html>

app/view.py 中代码如下

from . import models from django.http import HttpResponse from django.template import loader # Create your views here. def index(request):    lastes_question_list = models.Question.objects.order_by('-pub_date')[:5]    template = loader.get_template("app/index.html")    context = {"lastes_question_list": lastes_question_list}    return HttpResponse(template.render(context))
3 index.html不变,app/view 修改
from . import models from django.shortcuts import render # Create your views here. def index(request):    lastes_question_list = models.Question.objects.order_by('-pub_date')[:5]    context = {"lastes_question_list": lastes_question_list}    return render(request, template_name="app/index.html", context=context)
4 去掉static 和 url中的硬编码及反向解析

根据根路由中注册的namespace和子路由中注册的name来动态获取路径。在模板中使用"{% url  namespace:name %}"
如果携带位置参数 
“{% url  namespace:name  args %}"
如果携带关键字参数 
“{% url  namespace:name  k1=v1  k2=v2  %}"


配置 详情页面添加数据

app/view.py 中添加数据如下

from . import models from django.shortcuts import render # Create your views here. def index(request):    lastes_question_list = models.Question.objects.order_by('-pub_date')[:5]    context = {"lastes_question_list": lastes_question_list}    return render(request, template_name="app/index.html", context=context) def detal(request, question_id):    detal = models.Question.objects.get(pk=question_id)    context = {"detal": detal}    return render(request, template_name="app/detal.html", context=context)

app/urls.py中如下

from django.conf.urls import url, include from . import views urlpatterns = [    url(r'^index/$', views.index, name="index"),    url(r'^(?P<question_id>[0-9]+)/$', views.detal, name="detal"),# name 指定名称,用于后面的反向解析 ] ]

详情页html 配置如下

<!DOCTYPE html> <html> <head>    <meta charset="UTF-8">    <title>测试数据</title> </head> <body> {% if detal %} <h2>{{ detal.question_text }}</h2> {% for question in detal.choice_set.all %} <li>    {{ question.votes }}    {{ question.choice_text }} </li> {% endfor %} {% endif %} </body> </html>

index.html 修改如下

<!DOCTYPE html> <html> <head>    {% load static %}    <meta charset="UTF-8">    <title>测试数据</title> </head> <body> <img src="{% static  'django.jpg'%}"> {% if lastes_question_list %} <ul>    {% for question in lastes_question_list %}    <li>      <a href="{% url 'detal' question.id  %}"> {{question.question_text}} </a>    </li>    {% endfor %} </ul> {% endif%} </body> </html>

看完上述内容,你们掌握django的环境配置和view的使用方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。

文章名称:django的环境配置和view的使用-创新互联
文章出自:https://www.cdcxhl.com/article36/dsgcsg.html

成都网站建设公司_创新互联,为您提供外贸建站网站营销自适应网站网站导航面包屑导航品牌网站建设

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都网页设计公司