django中的MESSAGE组件

文章目录

    • message组件
      • [1 使用配置](#1 使用配置)
      • [2 设置值](#2 设置值)
      • [3 读取值](#3 读取值)
      • [4 源码分析](#4 源码分析)

message组件

1 使用配置

python 复制代码
INSTALLED_APPS = [
    # 'django.contrib.admin',
    # 'django.contrib.auth',
    # 'django.contrib.contenttypes',
    # 'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    "web.apps.WebConfig"
]
python 复制代码
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',
    'utils.md.AuthMiddleware'
]
python 复制代码
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        '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',
            ],
        },
    },
]
python 复制代码
# MESSAGE_STORAGE = 'django.contrib.messages.storage.fallback.FallbackStorage'
# MESSAGE_STORAGE = 'django.contrib.messages.storage.cookie.CookieStorage'
MESSAGE_STORAGE = 'django.contrib.messages.storage.session.SessionStorage'

2 设置值

在前页面视图中设置值

python 复制代码
from django.contrib import messages
messages.add_message(reqeust, messages.SUCCESS, "删除成功1")
messages.add_message(reqeust, messages.ERROR, "操作失败")

3 读取值

在后页面视图中读取值(读取值的同时,将值替换为本页面的message值,如果没有没有就为空列表)

  1. python代码中读取

    python 复制代码
    from django.contrib.messages.api import get_messages
    messages = get_messages(request)
    for msg in messages:
        print(msg)
  2. 前端模板代码中读取

    html 复制代码
    <ul>
        {% for message in messages %}
    	    <li>{{ message.tags }} {{ message }}</li>
        {% endfor %}
    </ul>

4 源码分析

message是一个对象(包裹)。

python 复制代码
from django.contrib import messages
messages.add_message(reqeust, messages.ERROR, "删除成功1")
messages.add_message(reqeust, messages.SUCCESS, "删除成功2", extra_tags="哈哈哈")

第一次访问

后一次访问

  • 【设置】中间件process_request加载,创建一个MESSAGE对象的实例(settings中配置的MESSAGE_STORAGE不同创建不同实例)

  • 【设置】在视图函数中往message中写入值(此时数据保存在内存中的列表中)

  • 【设置】中间件process_response,将内存中新增的数据写入到数据源(cookie或者session)

  • 【新页面】中间件process_request加载(创建一个新的MESSAGE对象)

  • 【新页面】在视图函数或模板中读取message中的信息(老的数据源加载的+新增的)

  • 【设置】中间件process_response

    复制代码
    used = True,则只保存新增部分。
    added_new = True,老的数据源加载的+新增的都重新保存到数据源。

若有错误与不足请指出,关注DPT一起进步吧!!!

相关推荐
zimoyin14 小时前
解决导入的数据库中因为 sql_mode 不同 视图无法打开问题
数据库·sql
程序边界14 小时前
MySQL至KingbaseES迁移最佳实践(上篇):迁移准备与实施规划
数据库·mysql
IvorySQL14 小时前
Oracle 19c数据库迁移到IvorySQL 4.6实战
数据库
kanimito15 小时前
开始改变第六天 MySQL(2)
数据库·mysql
晓py15 小时前
理解 MySQL 架构:从连接到存储的全景视图
数据库·mysql·架构
DemonAvenger15 小时前
Redis分布式锁:实现原理深度解析与实战案例分析
数据库·redis·性能优化
NineData16 小时前
NineData社区版 V4.6.0 正式发布!SQL 窗口新增4个数据源,新增支持OceanBase等多条数据复制和对比链路
数据库·sql·dba
IT果果日记16 小时前
给DataX配置加密的方法
大数据·数据库·后端
小白学鸿蒙16 小时前
鸿蒙数据库表中的数据如何导出为Excel存到系统下载目录
数据库·excel·harmonyos
WKP941816 小时前
mysql的事务、锁以及MVCC
数据库·mysql