三板斧的使用、全局配置文件、静态文件的配置、orm介绍

三板斧的使用

【1】HttpResponse

  • 返回字符串类型

【2】render

  • 返回html页面,并且在返回给浏览器之前还可以给html页面传值

【3】redirect

  • 重定向页面

视图函数必须返回一个 HttpResponse 对象

def index(request):
    print('request')
    # return HttpResponse("request") # 它返回的是字符串
    # return render(request, 'index.html') # 加载HTML页面的
    # return redirect('http://www.baidu.com') # 加载HTML页面的
    return redirect('/home/') # 重定向的

全局配置文件

LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = False

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config', # 这是全写
]

静态文件的配置

静态文件配置说明

  • 我们将html文件默认都放在templates文件夹

  • 我们将网站所使用的静态文件默认都放在static文件夹下

 静态文件:前段已经写好,能直接使用的文件
    网站写好的JS文件
    网站写好的CSS文件
    网站用到的图片文件
    第三方框架
    ...
拿来直接就可以使用的文件

  • 一般情况我们再static文件夹下还会对文件进行划分

    • js文件夹
    • css文件夹
    • img文件夹
    • plugins文件夹
  • 在浏览器中输入url能够看到对应的资源

  • 是因为后端提前开设了相关的接口

  • 如果访问不到资源,说明后端没有开设相关资源的端口

静态文件配置

  • 配置文件
  • settings.py
STATIC_URL = '/static/'  # 类似于访问静态文件的令牌
'''如果想要访问static静态文件,就必须以static开头'''
'''
/static/plugins/Bootstrap/js/bootstrap.js/bootstrap.min.js
/static/ ---- 令牌
允许在以下列表中依次进行查找
如果没有则报错
'''
# 静态文件配置
STATIC_DIRS = [
    os.path.join(BASE_DIR, 'static')
]

静态文件动态解析

  • HTML文件

{% load static %}

<!--  本地 链接 引入方法  -->
    <!--  Websource 文件夹 拷贝到当前文件夹下即可使用  -->
    <!--  jQuery 文件  -->
    <script src="{% static 'plugins/Bootstrap/js/bootstrap.min.js' %}"></script>
    <!--  Bootstrap 的 JS 文件 (动画效果需要jQuery)  -->
    <script src="{% static 'js/jquery.min.js' %}"></script>
    <!--  Bootstrap 的 CSS 样式文件  -->
    <link rel="stylesheet" href="{% static 'plugins/Bootstrap/css/bootstrap.min.css' %}">
    <!-- bootstrap-sweetalert(弹框) 的 CSS 文件   -->
    <link rel="stylesheet" href="{% static 'plugins/bootstrap-sweetalert/dist/sweetalert.css' %}">
    <!-- bootstrap-sweetalert(弹框) 的 JS 文件 -->
    <script src="{% static 'plugins/bootstrap-sweetalert/dist/sweetalert.min.js' %}"></script>
  • settings.py
STATIC_URL = '/static/'  # 类似于访问静态文件的令牌
'''如果想要访问static静态文件,就必须以static开头'''
'''
/static/plugins/Bootstrap/js/bootstrap.js/bootstrap.min.js
/static/ ---- 令牌
允许在以下列表中依次进行查找
如果没有则报错
'''
# 静态文件配置
STATIC_DIRS = [
    os.path.join(BASE_DIR, 'static')
]

request对象的方法

<form action="" method="post">
action:
	1. 不写,朝当前地址提交
    2. 全写
    3. 只写后缀
    
# post提交表单,前期先把下面的代码注释掉
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    # 'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

print(request.GET)
print(request.GET.get('a'))
print(request.GET.get('b'))
print(request.GET.get('c'))
print(request.GET.getlist('c'))

# print(request.POST) # 获取以post请求方式提交的表单数据
# print(request.POST.get('username')) # kevin 获取以post请求方式提交的表单数据
# print(request.POST.get('password')) # 123 获取以post请求方式提交的表单数据
"""get获取默认拿到的是最后一个元素值"""
# print(request.POST.get('hobby')) # 3 获取以post请求方式提交的表单数据
# ['a', 'b', 'c']
username = request.POST.get('username')
password = request.POST.get('password')
print(request.POST.getlist('hobby')) # 3 获取以post请求方式提交的表单数据

request.method == 'POST':

django链接数据库

配置完链接数据的代码之后,Django默认启动不起来了,原因是:内部使用的链接模块用的是mysqldb
我们不使用这个模块,我们使用pymysql模块

如何更换pymysql

在任意的__init__.py文件中添加一下代码
import pymysql
pymysql.install_as_MySQLdb()

orm介绍

orm: 对象映射模型
在Django中操作数据库就不用在写原生的SQL语句,而是使用面向对象的语法和一些方法来操作数据库
缺点:代码的封装程度太高,导致的问题:执行效率下降了,目前可以忽略,需要自己写原生SQL语句

类名                    >>>              表名
对象                    >>>                一条记录
属性                    >>>                一个字段

我们的这些orm在哪里书写呢?

models.py这个文件就是跟数据库打交道的

 类名写好之后,一定别忘了做数据库迁移命令

重点:

python38 manage.py makemigrations  # 生成迁移的记录(类似以是一个小本本)
python38 manage.py migrate          # 这句话才是真正的操作了数据库,然后生成表
当你修改了跟数据量相关的代码之后,都要执行这两句话

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值