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等的更多相关文章

  1. Django创建项目及app

    主要环境为python3.5,编译环境为pycharm 首先已经安装好Django相关的组件 1.首先创建Django程序: windows系统下pycharm创建步骤: File->New P ...

  2. django1.9 创建项目和app并初始化项目

    创建项目: django-admin startproject  mytest04 创建app: python manage.py startapp app04 配置:settings.py 1. 2 ...

  3. thinkphp3.2笔记(5)创建项目 创建模型 实例化

    一 创建项目 1 拷贝框架 目录   public   thinkphp  .htaccess  index.php    [application不用拷贝,会自动生成] 2   public 下面创 ...

  4. django rest framework 项目创建

    Django Rest Framework 是一个强大且灵活的工具包,用以构建Web API 为什么要使用Rest Framework Django REST Framework可以在Django的基 ...

  5. Web框架之Django_01初识(三大主流web框架、Django安装、Django项目创建方式及其相关配置、Django基础三件套:HttpResponse、render、redirect)

    摘要: Web框架概述 Django简介 Django项目创建 Django基础必备三件套(HttpResponse.render.redirect) 一.Web框架概述: Python三大主流Web ...

  6. VUE创建项目

    Vue Cli项目搭建     vue项目需要自建服务器:node 什么是node: 用C++语言编写,用来运行JavaScript语言 node可以为前端项目提供server (包含了socket) ...

  7. djiango 虚拟环境与项目创建

    建立虚拟环境 一,查看有那些虚拟环境 :workon 二,创建虚拟环境:mkvirtualenv -p/usr/bin/python3 django(p后面是路径) 三,进入虚拟环境:workon d ...

  8. Vue学习笔记-nodejs+vue-cli4+webpack按装配置+项目创建

    一  使用环境: windows 7 64位操作系统 二  Vue学习-nodejs按装配置,Node.js 就是运行在服务端的 JavaScript. 1. 去nodejs的官网下载  https: ...

  9. vue(16)vue-cli创建项目以及项目结构解析

    vue-cli创建项目 上一篇我们安装了vue-cli,接下来我们就使用该脚手架进行创建项目 1.进入一个目录,创建项目 创建项目命令如下: vue create <Project Name&g ...

随机推荐

  1. 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 ...

  2. BOA服务器搭建步骤

    1.下载Boa Webserver的源码 http://www.boa.org/ 2.解压并编译Boa Webserver $ tar xvf boa-0.94.13.tar.gz 由于Boa Web ...

  3. [C++11新特性] 智能指针详解

    动态内存的使用很容易出问题,因为确保在正确的时间释放内存是极为困难的.有时我们会忘记释放内存产生内存泄漏,有时提前释放了内存,再使用指针去引用内存就会报错. 为了更容易(同时也更安全)地使用动态内存, ...

  4. BZOJ2006 超级钢琴

    Description ​ 给定一个长度为n的区间,询问前k大的区间和,区间长度\(\in [L, R]\). $ n, k <= 500000$ Solution ​ 首先求前缀和.把一个区间 ...

  5. vijos1846 [NOIP2013] 华容道【最短路】

    传送门:https://vijos.org/p/1983 (其实noip的题各个oj都会有的,就不贴其它传送门了) 这道题真的是,怎么说,我都不知道怎么评价了= =.果然数据量小的题怎么暴力都可以过. ...

  6. synchronized(5)修饰语句块之:synchronized(XXX.class)

    synchronized(XXX.class)有两种写法 synchronized(XXX.class)或者synchronized(obj.getClass()) Class也是一个类xxx.cla ...

  7. 聊聊mq中消息消费的几种方式

    mq系列文章 对mq了解不是很多的,可以看一下下面两篇文章: 聊聊mq的使用场景 聊聊业务系统中投递消息到mq的几种方式 聊聊消息消费的几种方式 如何确保消息至少消费一次 如何保证消息消费的幂等性 本 ...

  8. java基础(六):RabbitMQ 入门

    建议先了解为什么项目要使用 MQ 消息队列,MQ 消息队列有什么优点,如果在业务逻辑上没有此种需求,建议不要使用中间件.中间件对系统的性能做优化的同时,同时增加了系统的复杂性也维护难易度:其次,需要了 ...

  9. flex弹性布局操练2

    上一个是练习的1个内元素的,这次练习两个元素的. ul.box1 { list-style:none; background-color:black; display:flex; justify-co ...

  10. NGUI利用深度测试实现新手引导遮罩

    实现原理:实际上就是先利用渲染队列渲染,然后再利用ZTest,改变渲染的遮挡关系. PS:Depth Testing:深度测试,也叫深度缓冲.只有最靠近观察者的物体会被绘制.深度即Z,该值越小表示离观 ...