Django实例
更新:今年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,然后由全局路由函数调用本地路由,最后被调用的网页也要注明被调用的绝对路径。
最新文章
- 如何解决inline和linline-block在浏览器中的间距问题
- C#+ AE 注意问题汇总(不断更新)
- 为图片添加九宫格信息-UI界面编辑器(SkinStudio)教程
- paip.函数式编程方法概述以及总结
- mysql优化之连接优化(open-files-limit与table_open_cache)
- JDBC连接数据库 prepareStatement
- NodeJs技术
- php简单分页
- 实验吧_密码忘记了(vim编辑器+代码审计)&;天网管理系统(php弱比较+反序列化)
- es6涉及的那点东西
- C# Html格式内容转Csv内容包括table(重点在rowspan和colspan合并),p,div元素
- 多线程 start 和 run 方法到底有什么区别?
- Linux常用命令之压缩和解压缩命令
- 今天开始学Pattern Recognition and Machine Learning (PRML),章节5.2-5.3,Neural Networks神经网络训练(BP算法)
- Webservice学习之WSDL详解
- 第九节 JS运动应用
- Android - Resource 之 String 小结
- [boost] : test库
- python的socket.recv函数陷阱
- dropload.js 上滑加载,下拉刷新
热门文章
- BSGS与扩展BSGS
- PHP-max_execution_time与fpm.request_terminate_timeout介绍
- 机器学习 - 损失计算-softmax_cross_entropy_with_logits
- 我对SAP Business One 项目实施的理解
- python3 asyncio-协程模块测试代码
- Linux vi 编辑器常见命令的使用
- warning: ISO C++ forbids converting a string constant to 'char*' [-Wwrite-strings]
- ceph简单用户管理
- 【转】Python3 操作符重载方法
- Set集合判断对象重复的方法