Django入门基础(小白版))

1.简介

ython下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。

Django是一个开放源代码的Web应用框架,由Python写成。

Django遵守BSD版权,初次发布于2005年7月, 并于2008年9月发布了第一个正式版本1.0 。

Django采用了MVC的软件设计模式,即模型M,视图V和控制器C。

1.1学习本教程前你需要了解:

Django 版本对应的 Python 版本:


图片.png

2.安装Django(没安装python的自行安装)

这里环境选用python2.7+1.11

  • 源码安装
    下载源码
    然后 到django目录下 运行 pip install -e django/
  • pip 安装 [推荐]
    Install : pip install django(过程可能会比较慢,会安装最新版)
    install:* 源码安装
    下载源码
    然后 到django目录下 运行 pip install -e django/
  • pip 安装 [推荐]
    Install : pip install django(过程可能会比较慢,会安装最新版)
    install:pip install django==1.11.1(指定版本号安装)

查看是否安装成功:进入解释器

import Django

查看版本:退出解释器,cmd中输入

python -m django --version

3.创建项目

django-admin startproject projectname

比如输入:django-admin startproject myblog

(可输入django-admin查看有django有哪些命令)

3.1启动项目:

django自带小型服务器

  • python manage.py runserver 9999#自己指定端口
  • python manage.py #使用默认8000端口

3.2目录结构

图片.png
  • manage.py: 文件是项目管理文件,一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互。
  • myblog: 项目的容器。
  • myblog/init.py: 一个空文件,告诉 Python 该目录是一个 Python 包。
  • myblog/settings.py: 该 Django 项目的设置/配置。最核心
  • myblog/urls.py: 该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录",配置URL文件。
  • myblog/wsgi.py: Python Web Server Gateway Interface(python服务网关接口,Python应用与web服务器之间的接口)

4.创建应用

进入manage.py同级目录

python manage.py startapp blog#blog为应用名称

添加应用名到settings.py中的INSTALLED_APPS 里

INSTALLED_APPS = [
    ...
    'blog',
]

目录结构:


文件作用:

  • admin.py: 当前应用的后台管理系统配置。
  • migrations: 数据移植模块。
  • migrations/init.py: 一个空文件。
  • apps.py: 当前应用的配置.最核心
  • models.py: 数据模块,使用ORM框架,类似MVC结构中Models的作用
  • test.py: 自动化测试模块。
  • views.py:执行响应的代码所在模块,代码逻辑处理的主要地点,主要代码编辑区域

5.创建第一个页面(响应)

  • 编辑blog.views
    每个响应对应一个函数,函数必须返回一个响应
    函数必须存在一个参数,一般设定为request
    每个响应对应一个url
from django.http import HttpResponse
def index(request):
    return HttpResponse('hello jaymo!')
  • 编辑urls.py
    每个URL都以url的形式写出来
    url函数放在urlpatterns列表中
    url函数三个参数;URL(正则),对应方法,名称
import blog.view as bv
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^index/', bv.index),#新增

]

5.1启动服务

在manage.py同级目录下cmd中输入:

python manage.py runserver 9999

打开浏览器输入:

http://127.0.0.1:9999/index/

结果显示.png
  • 配置url方法二

    编辑urls.py

from django.conf.urls import url,include
from django.contrib import admin
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^blog/', include('blog.urls')),
]

更改为^blog,地址以blog开头
在app目录下新建urls.py文件

from django.conf.urls import url
from .import views
urlpatterns = [
    url(r'^index//pre>, views.index),
]

正则表达式(RE)可为空(r'^/pre>),也可为固定的一个地址,注意index后的'/'

在浏览器地址栏中输入http://127.0.0.1:8000/blog/index/ 即可

  • 注意事项
    根urls.py针对app配置的url名称,是该app所有url的总路径

    配置url时注意正则表达式结尾符号$和/

6.开发一个template(界面)

template

是一个HTML文件
使用了Django模板语言(Django Template Language,DTL)(引擎)
可以使用第三方模板(如Jinja2)

步骤

  • 在app根目录下创建名为Templates的目录
  • 在该目录下创建HTML界面
  • 在views.py中返回render()
def index(request):
    return render(request, 'index.html')
图片.png

DTL初步使用

views.py文件中render()函数中支持一个dict类型参数
该字典是后台传递到模板的参数,键为参数名

return render(request, 'index.html',{'hello':'hello jaymo blog'})

在模板Templates/index.html中使用{{参数名}}来使用

<body>
<h1>{{hello}}</h1>
</body>

图片.png

此处有坑
此时再新建一个app,此目录下Templates中的html界面命名与之前app一样,则django会按照installed_app中的顺序查找,以至于会忽略掉新建的template

解决办法:将app的Templates目录下创建与app同名的目录
将html文件放入该目录中,同时更改views.py文件中的render()第二个参数

7.Models

  • 概念:
    通常,一个Model对应数据库的一张数据表
    Django中Models以的形式表现
    它包含了一些基本字段以及数据的一些行为

ORM:
实现了ORM(对象关系映射)
实现了对象和数据库之间的映射
隐藏了数据访问细节(封装了数据库的操作,不用写SQL语句)

  • 步骤

    在应用根目录下创建models.py,并引入models模块
    创建类,继承models.Model,该类即使一张数据表
    在类中创建字段
    字段即类中的属性(变量)

title = models.CharField(max_length = 32,default = 'title')
content = models.TextField(null = True)

详情查看官方网站:https://docs.djangoproject.com/en/1.10/ref/models/fields/

生成数据表

步骤

  • 在命令行中进入manage.py同级目录
  • 执行 python manage.py makemigrations app名(可选),这是准备
  • 再执行 python manage.py migrate
    查看
  • Django会自动在app/migreations/目录下生成移植文件
  • 执行python manage.py sqlmigrate appname 文件id 查看sql语句,比如 python manage.py sqlmigrate blog 0001
CREATE TABLE "blog_article" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "title" varchar(32) NOT NULL, "content" text NULL);

查看db.sqlite3的第三方软件:
SQLite Expert personal
轻量级,完全免费

8.页面呈现数据

  • 后台步骤
    修改views.py
from. import models

article = models.Article.objects.get(pk=1)
return render(request, 'blog/index.html', {'article': article})

注意:这里是应用了配置url方法二。
前端步骤
index.html模板可直接使用对象以及对象的"."操作

<body>
<h1>{{article.title}}</h1>
<h3>{{article.content}}</h3>
</body>

9.Admin

简介

  • 自带的自动化数据管理界面
  • 被授权的用户可直接在admin中管理数据库
  • 许多针对Admin的定制功能

配置

  • 创建用户
    python manage.py createsuperuser

localhost:9999/admin
登录admin:


图片.png
  • 修改admin界面为中文
    修改settings.py 中LANGUAGE_CODE = 'zh_Hans'


    图片.png

配置应用(增加数据库管理)
在应用下admin.py中引入自身的models模块(或里边的模型类)

from models import Article

编辑 admin.py:
admin.site.register(models.Article)

admin.site.register(Article)

图片.png

添加Articles:

图片.png

访问http://localhost:9999/blog/index/
图片.png

修改数据默认显示名称

  • 在Article下添加一个方法:
def __unicode__(self):(python 2.X)
        return self.title

or

def __str__(self):(python 3.X)
        return self.title
图片.png

10.完善博客

博客页面设计
页面概要

  • 博客主页面
  • 博客文章内容页面
  • 博客撰写页面

10.1 博客主页面

主页面内容

  • 文章标题列表,超链接
  • 发表博客按钮(超链接)

列表编写思路

  • 读取数据库中所有文章对象

  • 将文章对象们打包成列表,传递到前端

  • 前端页面把文章以标题超链接的形式逐个给出

实现思路
模板For循环
{% for xx in xxs %}
HTML语句
{%endfor %}

具体实现
后台代码,修改views.py

def index(request):
    articles = models.Article.objects.all()
    return render(request, 'index.html', {'articles': articles})

前端代码,修改index.html

<h1><a href="">新建文章</a></h1>
{% for article in articles %}
    <a href="">{{article.title}}</a>
    <br>
{% endfor %}

图片.png

博客文章界面
编写思路

  • 标题
  • 文章内容
  • 修改文章按钮(超链接)

具体实现:
在views.py中增加一个响应

def article_page(request, article_id):
    article = models.Article.objects.get(pk=article_id)
    return render(request,'blog/article_page.html',{'article':article})
  • 配置app目录下的urls.py文件,正则中的组名必须和参数名一致
url(r'^article/(?P<article_id>[0-9]+)$', views.article_page),

编写界面,在index.html同级目录下新建article_page.html文件:

<body>
    <h1>{{article.title}}</h1>
    <br/>
    <h3>
        {{article.content}}
    </h3>
    <br/><br/>
    <a href="">Edit</a>
   </body>

浏览器输入 http://127.0.0.1:9999/blog/article/1验证

图片.png

超链接配置
超链接目标地址

  • href后面是目标地址
  • template中可以用"{% url 'app_name:url_name' param %}"

其中app_name和url_name都在url中配置

再配URL

  • 根urls,写在include()的第二个参数位置,
    namespace = 'blog'
    url(r'^blog/', include('blog.urls', namespace='blog')),
  • 应用下则写在url()的第三个参数位置,name = 'article'
url(r'^article/(?P<article_id>[0-9]+)$',
        views.article_page, name='article_page'),

主要取决于是否使用include引用了另外一个url配置文件

  • 修改index.html
    <a href="{% url 'blog:article_page' article.id%}">{{article.title}}</a>

博客撰写页面

页面内容

  • 标题编辑栏
  • 文章内容编辑区域
  • 提交按钮

实现

新建页面edit_page.html:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Edit Page</title>
</head>
<body>
<form action="" method="post">
    <label for="">
文章标题:<input type="text" name="title">
    </label>
<label for="">
文章内容:<input type="text" name="content">
</label>
<input type="submit" value = "提交>
</form>
</body>
</html>

表单编辑响应函数
使用request.POST['参数名']获取表单数据,使用models.Article.objects.create(title, content)创建对象,写入数据库,然后返回主页:

def edit_action(request):
    title = request.POST.get('title', 'TITLE')
    content = request.POST.get('content', 'CONTENT')
    models.Article.objects.create(title=title, content=content)
    articles = models.Article.objects.all()
    return render(request, 'blog/index.html', {'articles': articles})

图片.png

如果出现这个页面,在edit_page.html表单中添加:{% csrf_token%}

博客修改页面
思路

  • 新文章为空。修改文章有内容
  • 修改文章页面有文章对象
  • 文章的ID

来源:https://www.imooc.com/learn/790

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,029评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,395评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,570评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,535评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,650评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,850评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,006评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,747评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,207评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,536评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,683评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,342评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,964评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,772评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,004评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,401评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,566评论 2 349

推荐阅读更多精彩内容