本文根据 菜鸟教程的Django轨迹学习:http://www.runoob.com/django/django-tutorial.html
一、根据菜鸟教程的资料自学
python:http://www.runoob.com/python3/python3-tutorial.html
python框架Django:http://www.runoob.com/django/django-tutorial.html
菜鸟网的有点跳,这个写的比较细。https://code.ziqiangxuetang.com/django/django-tutorial.html
二、python安装
根据Django的安装教程,会教你同时安装python和Django http://www.runoob.com/django/django-install.html
1.python安装:http://www.runoob.com/python/python-install.html
进入https://www.python.org/downloads/release/python-365/
我电脑是window10系统,所以选择Windows x86-64 executable installer 进行安装,记得选择要加入PATH。
2.django安装
https://github.com/django/django 下载django
下载 Django 压缩包,解压并和Python安装目录放在同一个根目录。用命令行(快捷键win+R,输入cmd)进入django的目录,进行安装
前两行是安装python时勾选了自动配置python的环境变量,而自动配置的python的环境变量.
第四行是手动增加的django环境变量(打开该文件夹直接复制,不会出错)
测试是否安装成功
打开命令行,或启动python IDLE,输入python启动python,在输入导入import 和 getversion
三. 创建 project
坑:在cmd中一直报错。
出坑:要退出python环境,输入exit()退出python环境,在cmd默认环境中输入
从而知道你cd到哪,django就在那创建project。
就创建了d盘下的helloworld文件夹,windows下要用tree/F
四、启动服务器
上图提示有很多app的设置没有设置。
打开浏览器,输入 http://127.0.0.1:8000/。 报错!但说明安装成功了。
更改setting.py,要不一直报错
ALLOWED_HOSTS=['*']
四、写项目
1、在先前创建的 HelloWorld 目录下的 HelloWorld 目录新建一个 view.py 文件,并输入代码:
个人习惯用sublime3,就用了sublime了。
from django.http import HttpResponse
def hello(request):
return HttpResponse("Hello world ! ")
2、接着,绑定 URL 与视图函数。打开 urls.py 文件,删除原来代码,将以下代码复制粘贴到 urls.py 文件中:
from django.conf.urls import url
from . import view
urlpatterns = [
url(r'^$', view.hello),
]
完成后,启动 Django 开发服务器,并在浏览器访问打开浏览器并访问:http://127.0.0.1:8000/
五、模板
1、在 HelloWorld 目录底下创建 templates 目录并建立 hello.html文件
<h1>{{ hello }}</h1>
从模板中我们知道变量使用了双括号。
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [BASE_DIR+"/templates",], # 修改位置
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
2. 修改 view.py,增加一个新的对象,用于向模板提交数据:
#第二个案例
from django.shortcuts import render
def hello(request):
context = {}
context['hello'] = 'Hello World!'
return render(request, 'hello.html', context)
我们这里使用 render 来替代之前使用的 HttpResponse。render 还使用了一个字典 context 作为参数。
context 字典中元素的键值 "hello" 对应了模板中的变量 "{{ hello }}"。
六、模板标签 (跟thinkphp5的模板比较类似,我跳的快一些)
1、 if/else
{% if condition1 %}
... display 1
{% elif condition2 %}
... display 2
{% else %}
... display 3
{% endif %}
根据条件判断是否输出。if/else 支持嵌套。
{% if %} 标签接受 and , or 或者 not 关键字来对多个变量做判断 ,或者对变量取反( not ),例如:
2、for
循环语法是 for X in Y ,Y是要迭代的序列而X是在每一个特定的循环中使用的变量名称。
每一次循环中,模板系统会渲染在 {% for %} 和 {% endfor %} 之间的所有内容。
{% for athlete in athlete_list %}
<li>{{ athlete.name }}</li>
{% endfor %}
给标签增加一个 reversed 使得该列表被反向迭代:
可以嵌套使用 {% for %} 标签:
3、ifequal/ifnotequal ( 个人疑问:为啥不用if的条件判断?还要单独整个函数,那if大于 或者 if小于 呢?)
4、注释
{# 这是一个注释 #}
5、过滤器 (类似tp5的文档中对变量使用函数)
模板过滤器可以在变量被显示前修改它,过滤器使用管道字符
过滤管道可以被* 套接 :
{{ my_list|first|upper }}
过滤器的参数跟随冒号之后并且总是以双引号包含
{{ bio|truncatewords:"30" }}date : 按指定的格式字符串参数格式化 date 或者 datetime 对象,实例:
{{ pub_date|date:"F j, Y" }}6、include
{% include %} 标签允许在模板中包含其它的模板的内容。
7、模板继承模板可以用继承的方式来实现复用。
接下来我们先创建之前项目的 templates 目录中添加 base.html 文件,代码如下:
HelloWorld/templates/base.html 文件代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body>
<h1>Hello World!</h1>
<p>菜鸟教程 Django 测试。</p>
{% block mainbody %}
<p>original</p>
{% endblock %}
</body>
</html>
以上代码中,名为 mainbody 的 block 标签是可以被继承者们替换掉的部分。
所有的 {% block %} 标签告诉模板引擎,子模板可以重载这些部分。
hello.html 中继承 base.html,并替换特定 block,hello.html 修改后的代码如下:
HelloWorld/templates/hello.html 文件代码:
{% extends "base.html" %}
{% block mainbody %}<p>继承了 base.html 文件</p>
{% endblock %}
P.S.:
实际操作时在extend前有其他标签虽然注销了,但仍然报错说必须是第一个标签。
删除标签后,一切正常。
七、模型
因工作是node做的后台,所以这块看的比较略
1.数据库配置
2.创建 APP
Django规定,如果要使用模型,必须要创建一个app。我们使用以下命令创建一个 TestModel 的 app:
django-admin.py startapp TestModel
目录结构如下:
HelloWorld |-- TestModel | |-- __init__.py | |-- admin.py | |-- models.py | |-- tests.py | `-- views.py
八、表单
在模板的末尾,我们增加一个 rlt 记号,为表格处理结果预留位置。
表格后面还有一个{% csrf_token %}的标签。csrf 全称是 Cross Site Request Forgery。这是Django提供的防止伪装提交请求的功能。POST 方法提交的表格,必须有此标签。