zoukankan      html  css  js  c++  java
  • Django基本操作

    今日内容

    静态文件配置

    ​ 1 默认情况下所有的HTML文件是放在templa文件夹内

    ​ 2 什么是静态文件

    ​ 网站所使用的到的提前写好的css,js,第三方前端模块,图片,都叫做静态资源

    ​ 3 默认情况下网站所用到的静态文件资源全部会放到static文件夹下

    ​ 通常情况下,在static文件夹内部还会在建其它文件夹

    ​ css 文件夹

    ​ js 文件夹

    ​ font 文件夹

    ​ img 文件夹

    ​ bootstrap

    ​ fontawesome

    ​ 为了更加的方便管理

    ​ Django中需要你自己手动创建静态文件存放的文件夹

    	STATIC_URL = '/static/'  # 访问静态文件资源接口前缀  通常情况下接口前缀的名字也叫static
    	# 手动开设静态文件访问资源
    	STATICFILES_DIRS = [  # 静态资源所在的文件夹路径
    		os.path.join(BASE_DIR,'static'),  # 将static文件里面所有的资源暴露给用户
    		os.path.join(BASE_DIR,'static1'),  # 将static文件里面所有的资源暴露给用户
    		# os.path.join(BASE_DIR,'static2'),  # 将static文件里面所有的资源暴露给用户
    	]
    

    ​ 4 静态文件动态绑定

    	{% load static %}
    	<link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
    	<script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>
    

    ​ form表单默认是get请求

    ​ get请求也能够携带参数

    			http://127.0.0.1:8000/login/?username=jason&password=jason123
    			特点:url?xxx=xxx&yyy=yyy
    

    ​ 1 携带的数据不安全

    ​ 2 携带的数据大小有限制,最大不要超过4kB

    ​ 3 通常只会携带一些不是很重要的数据

    ​ action

    ​ 1 不写,默认朝当前地址提交

    ​ 2 只写后缀 /index

    ​ 3 写全路径 http://www.baidu.com

    ​ 前期我们在朝后端提交post请求出现403的情况、

    ​ 你需要去配置文件中注释掉一行内容

    		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',
    	]
    

    ​ Django后端的视图函数,默认处理的是get请求

    ​ 无论是发get请求还是post请求,都会执行视图函数

    	def login(request):
    		print('来啦 老弟~')
    		return render(request,'login.html')
    

    ​ get请求指向拿到login页面

    ​ post请求想提交数据,然后后端做校验

    ​ 如何判断当前请求方式

    		request.method  拿到的是字符串大写的请求方式   GET  POST
    		def login(request):
    			# if request.method == 'GET':
    			#     print('来啦 老弟~')
    			#     print(request.method,type(request.method))  # 获取前端请求方式
    			#     return render(request,'login.html')
    			# elif request.method == 'POST':
    			#     print('post业务逻辑')
    			#     return HttpResponse('收到了')
    			if request.method == "POST":
    				return HttpResponse('收到了')
    			return render(request,'login.html')
    

    request方法初始

    ​ request.method 获取请求方式,并且纯大写的字符串

    ​ request.POST 获取用户提交的post请求数据

    如何获取用户数据(******)
    		request.POST.get()  # 默认只会获取列表最后一个元素
    		request.POST.getlist()  # 如果你想获取列表 用getlist()
    		
    	request.GET     获取用户提交的get请求数据
    	如何获取用户数据(******)
    		request.GET.get()  # 默认只会获取列表最后一个元素
    		request.GET.getlist()  # 如果你想获取列表 用getlist()
    

    pycharm连接数据库(了解)

    Django连接MySQL

    ​ 必须要有两部操作

    ​ 1 settings文件配置

    		DATABASES = {
    				'default': {
    					'ENGINE': 'django.db.backends.mysql',  # 指定数据库类型
    					'NAME': 'day49',  # 指定库的名字
    					'USER':'root',  # 注意 键必须是全大写
    					'PASSWORD':'123qwe',
    					'HOST':'127.0.0.1',
    					'PORT':3306,
    					'CHARSET':'utf8'
    				}
    			}
    
    	2.主动告诉django 不要用默认的mysqldb连接 而是用pymysql
    		你可以在项目名下的__init__.py中书写
    		也可以在应用名下的__init__.py中书写
    		import pymysql
    		pymysql.install_as_MySQLdb()
    

    Django orm简介

    ​ orm 对象关系映射

    ​ 类 表

    ​ 对象 数据

    ​ 对象.属性 字段对应的值

    ​ 为什么要使用orm

    ​ 能够让不会数据库操作的人也能够简单方便的去操作数据库

    ​ orm的缺点

    ​ 封装程度太高,有时候会出现查询效率偏低的问题

    ​ 所以工作中,简单的用orm,复杂的用原声sql语句

    ​ Django中如何操作orm

    ​ 书写模型类

    ​ 去应用下的models.py中书写模型类

    ​ 之后在写Django项目的时候,一个Django就对应一个数据库

    ​ 不要出现多个项目使用同一个数据库的情况(***************************)

    	******************************数据库迁移(同步)命令***************************
    	1.python3 manage.py makemigrations  # 将数据库的修改 记录到小本本上(migrations文件内)
    
    	2.python3 manage.py migrate         # 将修改操作真正的同步到数据库中
    

    ​ 上面两条命令必须是成双成对出现的,只要修改了跟数据库相关的代码,你就必须重新执行上面两条命令

    模型表字段的增删改查

    ​ 字段的修改

    ​ 直接修改代码,然后执行数据库迁移命令即可(两条命令一条不能少)

    			# 方式1  设置默认值
    			email = models.EmailField(default='123@qq.com')  # varchar
    			# 方式2   允许字段为空
    			phone = models.BigIntegerField(null=True)
    			# 直接在提示中给默认值
    			gender = models.CharField(max_length=32)
    

    ​ 字段的删除

    ​ 直接注释掉对应的字段,然后在执行数据库迁移命令即可(谨慎使用)

    模型表数据的增删改查


    data = models.User.objects.filter(username=username) # <QuerySet [<User: User object>]>
    """
    filter返回的结果是一个"列表",里面才是真正数据对象
    filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系
    """
    user_list = models.User.objects.all() # models.User.objects.filter()
    """
    结果是一个"列表" 里面是一个个的数据对象
    """

    user_obj = models.User.objects.create(username=username,password=password)
    print(user_obj,user_obj.username,user_obj.password)
    create方法会有一个返回值 返回值就是当前被创建的对象本身

    改
    	models.User.objects.filter(id=edit_id).update(username=username,password=password)
        """
        批量操作  会将filter查询出来的列表中所有的对象全部更新
        """
    
    删(一般情况下不会使用)
    	models.User.objects.filter(id=delete_id).delete()
    	"""
    
  • 相关阅读:
    webpack-配置
    webpack-配置
    webpack-配置
    Maximum Depth of Binary Tree
    Maximum Depth of Binary Tree
    Maximum Depth of Binary Tree
    Maximum Depth of Binary Tree
    网页中嵌入swf文件的几种方法
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
    xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!
  • 原文地址:https://www.cnblogs.com/1012zlb/p/11924030.html
Copyright © 2011-2022 走看看