Django学习笔记 - 【01 基础知识】

一、Django基础知识

1、安装django

pip install django
python目录
	- python.exe
	- scripts
		- pip.exe
		- django-admin.exe
	- lib
		- 内置模块
		- site-packages
			- openpyxl
			- python-docx
			- flask
			- django

2、创建项目

django中项目会有一些默认的文件和默认的文件夹

2.1:打开终端

  • 进入需要创建项目的目录
  • 执行命令,创建项目
django-admin.exe startproject testone

3、项目文件介绍

mysite
	- manage.py    # 【项目的管理,启动项目,创建app,数据管理】(常用)
	- mysite       # 项目文件夹
		- __init__.py
		- asgi.py    # 接受网络请求(不要动)
		- settings.py    # 项目配置文件(常修改)
		- urls.py    # url和函数的对应关系(常修改)
		- wsgi.py    # 接受网络请求(不要动)

4、APP

- 项目
	- app,用户管理【表结构、函数、HTML模板、CSS】# 各自独立
	- app,订单管理
	- app,后台管理
	- app,网站
	- app,API
	- ……

4.1 安装app

# 进入项目所在目录,执行:
python3.9 manage.py startapp [app's name]

4.2 app目录文件说明

在这里插入图片描述

- app01
	|- migrations    # 固定,不用动:数据库变更记录
		|- __init__.py
	|- __init__.py
	|- admin.py    # 固定,不用动:django默认提供了admin后台管理
	|- apps.py     # 固定,不用动:app启动类
	|- models.py   # **重要**:对数据库进行操作
	|- tests.py    # 固定,不用动:单元测试
	|- views.py    # **重要**:函数

5、快速上手django

  • 确保app已注册【settings.py】

在这里插入图片描述

  • 编写url和视图函数的对应关系【urls.py】

  • 编写视图函数【app01/views.py】

在这里插入图片描述

  • 启动django项目

    • 命令行启动
    python manage.py runserver
    

在这里插入图片描述

5.1 再写一个页面

```python
- url -> 函数
- 函数

在这里插入图片描述

5.2 templates模板

在这里插入图片描述

5.3 静态文件

包括:图片,css,js

5.3.1 static目录

- 在app目录下创建static文件夹
- 在html中 load static 文件夹

在这里插入图片描述

    {% load static %}
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="utf-8">
        <title>用户列表</title>
        <link rel="stylesheet" href="{% static 'plugins/bootstrap-3.4.1/css/bootstrap.css' %}">
    </head>
    <body>
        <h1>用户列表</h1>
        <input type="text" class="btn btn-primary" value="新建" />
        {% comment %} <img src="{% static 'img/pic01.png'%}" alt="123"> {% endcomment %}
    </body>
    </html>
    ```
```python
    # settings.py
    # Internationalization
    # https://docs.djangoproject.com/en/4.0/topics/i18n/
    
    LANGUAGE_CODE = 'en-us'
    
    TIME_ZONE = 'UTC'
    
    USE_I18N = True
    
    USE_TZ = True
    
    # Static files (CSS, JavaScript, Images)
    # https://docs.djangoproject.com/en/4.0/howto/static-files/
    
    STATIC_URL = '/static/'
    
    # Default primary key field type
    # https://docs.djangoproject.com/en/4.0/ref/settings/#default-auto-field
    
    DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
    ```

6、模板语法

本质上:在HTML中写一些占位符,由数据对这些占位符进行替换和处理

```html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>TPL</title>
</head>
<body>
    <h1>模板语法学习</h1>
    <div>{{ n1 }}</div>
    <div>{{ n2.0 }}</div>
    <div>{{ n2.1 }}</div>
    <div>{{ n2.2 }}</div>

    <div>
        {% for item in n2 %}
            <span>{{item}}</span>
        {% endfor %}
    </div>
    <hr/>
    <ul>
        {% for k,v in n3.items %}
            <li>{{k}}:{{v}}</li>
        {% endfor %}
    </ul>
    <hr/>
    {{n4}}

    {% for item in n4%}
        <div>{{item.name}}  {{item.salary}}</div>
    {% endfor %}

    {% comment %} {{n5}}

    {% for item in n5  %}
        <span>{{item.fund_name}}:{{item.fund_type}},{{item.fund_rlevel}},{{item.syl_1n}}</span>
    {% endfor %} {% endcomment %}

    <hr/>
    {% if n1 == 'Hello Django' %}
        <h1>233333</h1>
    {% else %}
        <h1>344444</h1>
    {% endif %}
</body>
</html>
```

7、请求和响应

def something(req):
    # req 是一个对象,其中封装了用户发送过来的所有数据
    # 1 获取用户请求方式
    print(req.method)
    # 2 在URL上传值
    print(req.GET)
    # 3 POST:通过请求体传递数据
    print(req.POST)
    # 4 HttpResponse("返回内容")

    # 5 读取HTML的内容 + 渲染(替换) ---》生成新的字符串,返回给用户浏览器
    # return render(req,'something.html',{'title':'来啦老弟'})

    # 6 redirect : 重定向
    return redirect("https://www.baidu.com")
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值