Django笔记(二)

1.当启动项目的时候,有多个文件,其中只有一个是Django,要让pycharm识别,可以进行设置

第一步:File--setting

 

 第二步:

 

 这样pycharm就能识别这个文件是Django

2.在写一个新的功能的时候,先在views里面写逻辑语句,然后到urls里面配置url,最后在html中修改获取的参数,还有会用到(例如点击某个分类展示所有的文章)

 

def category(request,id):
    category_obj=models.Category.objects.filter(id=id).first()#是一个对象的数组,要取第一个数据,然后取其中的某个数据要用.name等
    articles=models.Article.objects.filter(category_id=id)
    return render(request,'category.html',{'articles':articles,'category_obj':category_obj})

 

当views里的函数有参数的时候,urls里面也要带上参数

path('category/<int:id>', views.category),#用尖括号代表url后面跟的是什么样的参数

 

3.前端代码的重复利用和后端代码的重复利用

前端代码复用代码:采取的方式是:先建立以个base页面将所有的共用的body、css、js放在页面上,在要扩展或个个页面不一样的地方,留一个接口,方便其他的页面复用

<link href="https://cdn.bootcss.com/twitter-bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet">
    <link href="https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
    <script src="/static/js/headroom.min.js"></script>
    <!-- blog CSS -->
    <link href="/static/css/base.css" rel="stylesheet">
    {% block css %}#可以咋具体的页面增加页面独有的css样式
    {% endblock %}
 <div class="row">
            {% block content %}#在body里添加具体的页面内容,可以有多个,但是名字不能重复
            {% endblock %}

 

<script>
    $(function () {
        var myElement = document.querySelector(".blog-navbar");
        var headroom = new Headroom(myElement);
        headroom.init()
    });
</script>
<script src="/static/js/base.js?v=20191123.0909890"></script>
{% block js %}#具体的页面增加特有的js
{% endblock %}

 

后端代码的重复利用:添加一个叫上下文本器,使用上下文本器的时候需要导入(写几个方法就需要写几个导入)不能忘记。

EMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR,'templates')],#寻找到放HTML的地址
        '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',
                'user.content_process.content_process',
                'user.content_process.process_title',#上下文管理器要配置
            ],
        },
    },
]

 

from . import models
def content_process(request):#把后端都用到的代码放在上下文本器中
    categories = models.Category.objects.all()
    return {'categories':categories}

def process_title(request):
    web_site=models.WebSite.objects.all().first()
    return {'web_site':web_site}

 

使用上下文管理器,代码的执行过程,首先执行views里面的代码,然后templates里面时候有上下文管理器,有的话再执行里面的代码,返回给views,再执行urls,最后修改前端的代码

4.前端把数据写到后台有两种方式:同步form形式和异步ajax形式

5.request里有哪些方法

   print(request.method) #请求方式
    print(request.GET)# url?key=vlauye
    print(request.POST)#url  key-vlaue
    print(request.COOKIES)
    print(request.path_info)  #请求的路径 /post /cate
    print(request.FILES) #获取文件
    print(request.META) #请求头相关的都在这里
    print(request.body) #body里面的内容

应用:获取前端页面的内容,写进数据库

def article(request):
    if request.method=='GET':
        return render(request,'post.html')
    else:
        title = request.POST.get('title')
        content = request.POST.get('content')
        category = request.POST.get('category')
        models.Article.objects.create(title=title,content=content,category_id=category)
        return HttpResponseRedirect('/')

 

6.使用Django自带的后台管理,快速的插入数据

进入django自带的后台管理:

首先进入django项目里

创建账号和密码

然后登录到后台http://127.0.0.1:8000/admin/,输入刚刚注册用户名和密码登录

在models里面新建一张表结构,然后到admin.py中register

class user_info(models.Model):
    name=models.CharField(verbose_name='用户名',max_length=15,unique=True)
    nick=models.CharField(verbose_name='昵称',max_length=20)
    passwd=models.CharField(verbose_name='密码',max_length=10)
    createTime=models.DateTimeField(verbose_name='创建时间',auto_now_add=True)
    updateTime=models.DateTimeField(verbose_name='更新时间',auto_now=True)
    class Meta:
        db_table = 'info'
        verbose_name = '用户信息'#在站点管理里展示表的名字
        verbose_name_plural = verbose_name#通常是复数展示,不写这个直接在verbose_name后面加上s
    def __str__(self):#写上这个函数,在增加或获取的时候返回的不是一个对象而是直观的数据
        return self.name
admin.site.register(models.user_info)

 

 这样可以快速的可视化增加删除数据,点击增加就可以增加数据和删除数据

为了更加直观的展示django里面的数据

class ArticleAdmin(admin.ModelAdmin):
    list_per_page = 10 #每页最多展示多少条数据

    list_display = ['id','title','content','create_time'] #展示哪些字段

    list_filter = ['category'] #按照哪些字段来筛选

    search_fields = ['title','content']
admin.site.register(models.Article,ArticleAdmin)

 

7.中间件

中间件的原理:中间可以做一下快速的处理,和代理类似

没有中间件:请求---views---template--urls--html

有中间件:请求--中间件---views---template--urls--html

from django.http import HttpResponse
from django.middleware.common import MiddlewareMixin

from . import models
class TestMiddleWare(MiddlewareMixin):

    def process_request(self,request):
        '''请求过来之后先走到的这里'''
        print('request....')
        path = request.path_info
        interface = models.Interface.objects.filter(path=path).first()
        if interface:
            return HttpResponse(interface.response)


    def process_response(self,request,response):
        #拦截返回的
        print('response....')
        return response

    def process_exception(self,request,exception):
        #拦截异常的
        print('出异常了。。')
        return HttpResponse('hhhh')

8.在一对多的关系

A表(文章表)对B表(类别表)是1对多的关系,一个类别一共有多少篇文章,可以只用一张表就可以查出数据

c_obj=models.Category.objects.get(name='C++')
print(c_obj.article_set.count())
c_obj.article_set后面可以点出其他的功能

 

posted @ 2020-09-02 16:55  测试freshman  阅读(121)  评论(0编辑  收藏  举报