更新:今年8月在深圳和嵩天老师居然见面了,很开心。嵩天老师很和蔼。

===========

今天看了嵩天老师的视频,感觉讲的很好,于是看着视频自己做了一个初步的实例认识。

步骤1,新建一个Web框架

新建代码:django-admin startproject mysite   #这里是名字叫mysite的项目名称(其实我这里用的是pycharm professional版本的建立Django方法建立的,实际上是一样的,环境是win10教育版+pycharm pro2016.3)

文件视图如下图所示:

mysite/                #最外层目录

mysite/            #工程目录,保存代码和文件

_init_.py      #将mysite定义为包的空文件

settings.py    #部署和配置文件

urls.py        #URL路由声明文件

wsgi.py        #基于WSGI(web service gate interface)

manage.py          #与Django工程交互的命令工具

步骤2-1创建一个具体的应用

进入mysite(最外层目录)然后代码创建应用

python manage.py startapp helloapp

创建过应用后,文件视图为:

mysite/                #最外层目录

helloapp/

migrations/

_init_.py

admin.py

apps.py

models.py

tests.py

views.py

mysite/            #工程目录,保存代码和文件

_init_.py      #将mysite定义为包的空文件

settings.py    #部署和配置文件

urls.py        #URL路由声明文件

wsgi.py        #基于WSGI(web service gate interface)

manage.py          #与Django工程交互的命令工具

步骤2-2,然后打开helloapp中的views.py,写入如下代码:

from django.http import HttpResponse
def hello(request): #把request当成用户的访问
return HttpResponse("This is your first webpage,fighting!") #访问时,hello函数返回句子。

步骤2-3,然后再打开mysite/urls.py,这一步是为了指定URL与响应之间的关系,改为:

from django.contrib import admin
from django.urls import path
from helloapp import views #把helloapp的views导入进来,这个views其实就是给我们展示在浏览器上的东西 urlpatterns = [
path('index/', views.hello), #注意加上这个逗号,path的参数一是某个URL,参数二是某个处理函数,表示URL与处理函数的关联
path('admin/', admin.site.urls),
]

然后我们要试运行一下,用代码:

python manage.py runserver(注意:在最外层目录下运行,运行方式是shift+右键),意思启动一个调试的web服务器,屏幕中会出现一个IP地址,http://127.0.0.1:8000/,将这个IP放入浏览器,你会发现hello函数中显示的句子出现在浏览器上。

这里是为什么呢?

是因为我们在urlpatterns中的“path('index/', views.hello),”定义了URL的子目录index/,故我们http://127.0.0.1:8000/index/

这就是我们最终得到的效果。

以上是我们做出的第一个APP,实际上一个真正的工程是可以由很多应用组成的,其中有互相之间的联系或调用关系。接下来我们再做另外一个能显示页面而不是一个句子的APP。

步骤1,新建一个APP名字为hello2app,

用python manage.py startapp hello2app实现。此时在第一层的mysite里就多了一个文件夹叫hello2app。

步骤2,在hello2app目录下创建templates目录,然后将Demo.html文件考入到这个目录中

接下来打开hello2app/views.py来完成对HTML完成响应这样一个功能。

具体代码如下:

from django.shortcuts import render
def hello(request):
return render(request,"Demo.html")
# Create your views here.

增加了返回操作之后,我们需要再设定本地路由,在hello2app/下新建urls.py,在本地路由中我们要指定本地路由与操作之间的关系,修改为:

from django.urls import path
from . import views urlpatterns = [
path('', views.hello)
]

步骤3,然后在全局路由文件中增加对本地路由的引用,在全局路由中(mysite/urls.py)我们需要引入include函数,即“from django.urls import path,include”具体代码如下:

from django.contrib import admin
from django.urls import path,include
from helloapp import views urlpatterns = [
path('index2/', include('hello2app.urls')),
path('index/', views.hello),
path('admin/', admin.site.urls),
]

步骤4,我们还需要增加对templates的路径设置,即在mysite/settings.py修改“DIRS”,具体修改为:

'DIRS': [os.path.join(BASE_DIR, 'hello2app/templates')],   #os.path.join是指将后面两个路径合并,BASE_DIR是工程路径+合理hello2app/tem...

步骤5,最后,我们用:

python manage.py runserver

来启动服务器,输入“http://127.0.0.1:8000/index2/”,得到:

便大功告成了。

注意:整个逻辑过程是如下,

对于第一个app,app里的views.py写好用户请求访问函数,然后由全局路由urls.py来调用,这时会产生views的页面效果。

对于第二个app,app里的views写好用户请求访问函数的一个网页,然后新建一个本地路由调用views,然后由全局路由函数调用本地路由,最后被调用的网页也要注明被调用的绝对路径。

Django实例的更多相关文章

  1. Web框架本质及第一个Django实例 Web框架

    Web框架本质及第一个Django实例   Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web ...

  2. 【Django实例】博客1

    (上一篇) 一.概述 Blog是一个博客应用. dbe工程的目录结构,参考<序言>的最后部分.blog应用位于/home/russellluo/Django/dbe/dbe/blog目录下 ...

  3. django实例收集

    django笔记(一)(模板渲染变量.字典.for循环.索引.条件语句) django笔记(二) django环境准备与笔记(三) django笔记(四) django笔记(五) Views的补充 w ...

  4. Web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  5. WEB框架本质和第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 总的来说:Web框架的本质就是浏览 ...

  6. Django之Web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  7. Django学习笔记之Web框架由浅入深和第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  8. DAY15-web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  9. Web的本质以及第一个Django实例.

       Web框架的本质:    所有的Web应用本质上就是一个socket服务器, 而用户的浏览器就是一个socket客户端. import socket sk = socket.socket() s ...

随机推荐

  1. MQ服务器奔溃解决过程

    1.MQ服务器崩溃调节: 今天具安卓前端反应, 从昨天下午开始线上服务器使用 电话号码登陆和 使用电话号码注册功能不能使用, 经过前端仔细排查怀疑是后端问题,之后经过与ios前端 确认, 定位为后端服 ...

  2. B-树(B树)详解

    具体讲解之前,有一点,再次强调下:B-树,即为B树.因为B树的原英文名称为B-tree,而国内很多人喜欢把B-tree译作B-树,其实,这是个非常不好的直译,很容易让人产生误解.如人们可能会以为B-树 ...

  3. vbox安装增强功能,实现宿主机文件夹共享并浏览器访问

    虚拟机版本:6.0.4 r128413 (Qt5.6.2) linux:centos7/6 点击菜单栏中的设备->安装增强功能,再reboot 获取内核版本号 uname -r 查看yum的内核 ...

  4. 2018年秋季学期《c语言程序设计》助教总结

    <c语言程序设计>第七周助教总结 <c语言程序设计>第八周助教总结 <c语言程序设计>第九周助教总结 <c语言程序设计>第十周助教总结 <c语言程 ...

  5. 第五节: EF高级属性(一) 之 本地缓存、立即加载、延迟加载(不含导航属性)

    一. 本地缓存 从这个章节开始,介绍一下EF的一些高级特性,这里介绍的首先介绍的EF的本地缓存,在前面的“EF增删改”章节中介绍过该特性(SaveChanges一次性会作用于本地缓存中所有的状态的变化 ...

  6. 大家都知道fastclick能解决300ms延迟,现在我们来看一下,使用方法

    1.在终端输入以下命令进行安装 npm install fastclick -S 2.在你用脚手架搭建好的项目中,找到mian.js这个入口文件,打开 3.在其中加入: import FastClic ...

  7. 【先验知识归纳】Flask快速入门

    本文参考:快速入门 - Flask 0.10.1 文档 路由 Flask使用route修饰器来关联URL与程序函数: @app.route('/') def hello_world(): return ...

  8. thymeleaf : input/select/radio回显

    thymeleaf中不用自己去写checked="checked" selected="selected"这种代码,他自己会选. input <input ...

  9. 第八节,Opencv的基本使用------存取图像、视频功能、简单信息标注工具

    1.存取图像 import cv2 img=cv2.imread('test.jpg') cv2.imwrite('test1.jpg',img) 2.图像的仿射变换 图像的仿射变换涉及图像的形状位置 ...

  10. HTML5 web存储之LocalStorage和sessionStorage

    什么是localstorage 前几天在老项目中发现有对cookie的操作觉得很奇怪,咨询下来是要缓存一些信息,以避免在URL上面传递参数,但没有考虑过cookie会带来什么问题: ① cookie大 ...