django-1创建项目创建app设置setting、urls、templates、views等
1. python -m django --version
查看版本 1.11.4
在需要创建项目的目录下执行:
2. django-admin startproject myblog => 创建名为myblog的项目
在项目的manage.py 同级目录下运行
3. python manage.py runserver 9999 =>以端口号9999打开server,通过浏览器127.0.0.1:9999访问(默认8000端口)
项目myblog目录分析:
myblog------wsgi.py => python服务器网关接口,与web服务器通信的关键,平时不会改动
-----urls.py 每个页面的配置,或每个应用的根路径配置
-----setting.py 非常重要,核心部分,很多内容要在其中改动
-----__init__.py 有这个文件,myblog可以作为引用的模块

setting.py文件结构分析
BASE_DIR 项目根目录
SECRET_KEY 创建项目时自动生成的 可无视
DEBUG 不要在生产环境打开
ALLOWED_HOSTS 如果将debug 改为false,将allow_hosts改为localhost,那么通过ip访问就报错
INSTALLED_APPS 在该项目下创建的任何应用,都要把名字加入这个列表中 比如4. 创建的blog 需要将名字加入
ROOT_URLCONF ='myblog.urls' 貌似自动生成的吧
TEMPLATES 模板配置 htmlm文件,
使用了django模板语言 Django Template Language DTL
叫模板引擎
在第一行:'BACKEND': 'django.template.backends.django.DjangoTemplates'
也可以使用第三方引擎 Jinja2
WSGI_APPLICATION 无视 与网关配置相关的
DATABASES 默认使用DB为db.sqlite3
STATIC_URL 静态文件 html css等
在项目的manage.py 同级目录下运行
4. python manage.py startapp blog => 创建一个名为blog的应用
项目myblog下的应用:blog结构分析:
blog ------migrations => 数据迁徙 django自动生成
------admin => 当前应用的后台管理系统配置
------ apps => 当前应用的配置
------ models => 数据表
------ tests => 自动化测试模块
------ views =>执行响应的逻辑代码,项目中大部分代码在此
每个函数接收一个响应参数,再返回一个响应参数
每个函数对应一个url
去 myblog的urls.py 中添加函数同名对应的url,
然后 python manage.py runserver 就可以在浏览器中访问刚才配置的url,可以看到view的函数返回内容了
5. 在setting.py 文件中加入到 install_apps列表中
6. 在app:blog的根目录下创建文件夹:templates
7. 在myblog/blog/templates下创建html文件:index.html
8. 在app:blog 的 view.py 中 添加函数index2, return render(request, 'index.html', 后台数据)
其中,render:渲染页面
request, 接收的响应参数
index.html 为html文件字符串
后台数据:支持dict类型参数,key在前端(html中,用双大括号{{}},不显示在终端页面),value是后台内容,最终显示在终端页面的
8.1 在项目myblog 的 urls.py 中,引入了include,可以引用app blog 和 blog2 的urls,
url(r'^blog/', include('blog.urls')),
url(r'^blog2/', include('blog2.urls')),
8.2 app blog 和 blog2 的urls.py 里面的函数路径可以为空,用正则匹配, 注意最后的斜杠写法,为空写成^$
url(r'^index/$', views.index),
url(r'^myblog/$', views.myblog),
9 添加新的应用app:blog2 其下也有index.html ,setting中添加好应用名字,urls中配置好路径,
发现 只能顺序找到第一个blog的templates/index.html,
即 : 不同app的templates 目录下同名html文件会造成冲突
解决办法: 在templates文件夹下,创建应用名字相同的文件夹
并在应用app 的 views.py文件的相关函数,第二个参数html文件字符串前加上app名字目录
def index(request):
return render(request,'blog/index.html',{'hello':'开花花django-1创建项目创建app设置setting、urls、templates、views等的更多相关文章
- Django创建项目及app
主要环境为python3.5,编译环境为pycharm 首先已经安装好Django相关的组件 1.首先创建Django程序: windows系统下pycharm创建步骤: File->New P ...
- django1.9 创建项目和app并初始化项目
创建项目: django-admin startproject mytest04 创建app: python manage.py startapp app04 配置:settings.py 1. 2 ...
- thinkphp3.2笔记(5)创建项目 创建模型 实例化
一 创建项目 1 拷贝框架 目录 public thinkphp .htaccess index.php [application不用拷贝,会自动生成] 2 public 下面创 ...
- django rest framework 项目创建
Django Rest Framework 是一个强大且灵活的工具包,用以构建Web API 为什么要使用Rest Framework Django REST Framework可以在Django的基 ...
- Web框架之Django_01初识(三大主流web框架、Django安装、Django项目创建方式及其相关配置、Django基础三件套:HttpResponse、render、redirect)
摘要: Web框架概述 Django简介 Django项目创建 Django基础必备三件套(HttpResponse.render.redirect) 一.Web框架概述: Python三大主流Web ...
- VUE创建项目
Vue Cli项目搭建 vue项目需要自建服务器:node 什么是node: 用C++语言编写,用来运行JavaScript语言 node可以为前端项目提供server (包含了socket) ...
- djiango 虚拟环境与项目创建
建立虚拟环境 一,查看有那些虚拟环境 :workon 二,创建虚拟环境:mkvirtualenv -p/usr/bin/python3 django(p后面是路径) 三,进入虚拟环境:workon d ...
- Vue学习笔记-nodejs+vue-cli4+webpack按装配置+项目创建
一 使用环境: windows 7 64位操作系统 二 Vue学习-nodejs按装配置,Node.js 就是运行在服务端的 JavaScript. 1. 去nodejs的官网下载 https: ...
- vue(16)vue-cli创建项目以及项目结构解析
vue-cli创建项目 上一篇我们安装了vue-cli,接下来我们就使用该脚手架进行创建项目 1.进入一个目录,创建项目 创建项目命令如下: vue create <Project Name&g ...
随机推荐
- bzoj 3527: [Zjoi2014]力【FFT】
大力推公式,目标是转成卷积形式:\( C_i=\sum_{j=1}^{i}a_jb_{i-j} \) 首先下标从0开始存,n-- \[ F_i=\frac{\sum_{j<i}\frac{q_j ...
- BOA服务器搭建步骤
1.下载Boa Webserver的源码 http://www.boa.org/ 2.解压并编译Boa Webserver $ tar xvf boa-0.94.13.tar.gz 由于Boa Web ...
- [C++11新特性] 智能指针详解
动态内存的使用很容易出问题,因为确保在正确的时间释放内存是极为困难的.有时我们会忘记释放内存产生内存泄漏,有时提前释放了内存,再使用指针去引用内存就会报错. 为了更容易(同时也更安全)地使用动态内存, ...
- BZOJ2006 超级钢琴
Description 给定一个长度为n的区间,询问前k大的区间和,区间长度\(\in [L, R]\). $ n, k <= 500000$ Solution 首先求前缀和.把一个区间 ...
- vijos1846 [NOIP2013] 华容道【最短路】
传送门:https://vijos.org/p/1983 (其实noip的题各个oj都会有的,就不贴其它传送门了) 这道题真的是,怎么说,我都不知道怎么评价了= =.果然数据量小的题怎么暴力都可以过. ...
- synchronized(5)修饰语句块之:synchronized(XXX.class)
synchronized(XXX.class)有两种写法 synchronized(XXX.class)或者synchronized(obj.getClass()) Class也是一个类xxx.cla ...
- 聊聊mq中消息消费的几种方式
mq系列文章 对mq了解不是很多的,可以看一下下面两篇文章: 聊聊mq的使用场景 聊聊业务系统中投递消息到mq的几种方式 聊聊消息消费的几种方式 如何确保消息至少消费一次 如何保证消息消费的幂等性 本 ...
- java基础(六):RabbitMQ 入门
建议先了解为什么项目要使用 MQ 消息队列,MQ 消息队列有什么优点,如果在业务逻辑上没有此种需求,建议不要使用中间件.中间件对系统的性能做优化的同时,同时增加了系统的复杂性也维护难易度:其次,需要了 ...
- flex弹性布局操练2
上一个是练习的1个内元素的,这次练习两个元素的. ul.box1 { list-style:none; background-color:black; display:flex; justify-co ...
- NGUI利用深度测试实现新手引导遮罩
实现原理:实际上就是先利用渲染队列渲染,然后再利用ZTest,改变渲染的遮挡关系. PS:Depth Testing:深度测试,也叫深度缓冲.只有最靠近观察者的物体会被绘制.深度即Z,该值越小表示离观 ...