django传递公共参数到模板

Django传递公共参数到界面方法详解
本文详细介绍了使用Django传递公共参数到界面的两种方法:中间件和RequestContext对象,包括设置步骤和使用示例。

因为显示需要,例如用户等信息是需要在每次请求传递回页面!

django传递公共的参数到界面有两种方法

1.中间件

修改settings.py配置信息 MIDDLEWARE_CLASSES 增加自定义的中间件

中间件的缺点是render_to_response无法触发process_template_response

必须返回带有render()方法的HttpResponse()的实例

class PublicParameter(object):
    def process_template_response(self, request, response):
        """
            传递公共数据
        """
        user = User.objects.get()
        if isinstance(response.context_data, dict):
            response.context_data['user'] = projectList
        else:
            response.context_data = {'user':projectList}
        return response


2.通过RequestContext对象

配置settings.py中 TEMPLATE_CONTEXT_PROCESSORS

TEMPLATE_CONTEXT_PROCESSORS = (
    "django.contrib.auth.context_processors.auth",
    "django.core.context_processors.debug",
    "django.core.context_processors.i18n",
    "django.core.context_processors.media",
    "django.core.context_processors.static",
    "django.contrib.messages.context_processors.messages",
    "myapp.public_parameter",
)

def public_parameter(request):
    user = User.objects.get()
    return {'user': user}

视图需要传递context_instance

def project(request):
    return render_to_response("test.html",context_instance=RequestContext(request),)


### Django 模板使用指南 #### 加载和渲染模板 Django模板加载机制允许通过指定路径来查找并加载 HTML 文件作为模板。为了使 Django 能够找到这些文件,在设置中需指明 `TEMPLATES` 配置项中的 `'DIRS'` 参数指向存储位置[^1]。 当准备就绪后,可以通过视图函数调用 `render()` 方法传递上下文数据给定名的模板来进行页面呈现操作: ```python from django.shortcuts import render def my_view(request): context = { 'key': value, } return render(request, 'my_template.html', context) ``` #### 自定义标签与过滤器 除了默认提供的工具外,还可以创建自己的模板标签或过滤器扩展功能集。这类组件通常放置于应用内部名为 `templatetags` 的包里,并遵循一定的命名约定以便导入使用[^5]。 对于想要修改变量显示形式的情况来说,过滤器尤为有用;它们可以链式调用来实现复杂转换逻辑而无需改变原始 Python 代码结构。 #### 继承与重载 继承特性使得父级布局能够被多个子页面共享公共部分的同时保持灵活性——只需简单声明 `{% extends "base.html" %}` 即可建立父子关系。接着利用 `{% block content %}...{% endblock %}` 定义特定区域供后代覆写填充具体内容。 这种模式极大地提高了开发效率减少了重复劳动量同时也便于维护统一风格的设计方案。 #### 处理静态资源 为了让 CSS、JavaScript 或者图片等非文本型资产正常工作,必须先告知框架其所在之处即配置好STATIC_URL 和 STATICFILES_DIRS 变量指向相应目录[^3]。之后便可在模板内安全引用此类链接而不必担心跨域等问题的发生。 ```html <!-- 假设设置了 STATIC_URL='/static/' --> <img src="{% static 'images/logo.png' %}" alt="Logo"> <link href="{% static 'css/style.css' %}" rel="stylesheet"> <script src="{% static 'js/app.js' %}"></script> ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值