django中使用jinja2模板,配置及相关的问题

本文档详细介绍了如何在Django项目中替换默认的模板引擎,使用Jinja2。步骤包括通过pip安装Jinja2,创建环境变量文件,配置settings中的TEMPLATES选项,注释admin应用和相关URL,以及设置urls和views。通过这些步骤,你可以实现Jinja2模板在Django项目中的顺利运行,并进行测试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.安装jinja2模板

# pip install Jinja2 -i https://pypi.doubanio.com/simple/
  • 1

2.在项目目录下创建jinja2环境变量文件

在这里插入图片描述

 

from django.contrib.staticfiles.storage import staticfiles_storage
from django.urls import reverse
from jinja2 import Environment

def environment(**options):
    env = Environment(**options)
    env.globals.update({                    # 修改
        'static':staticfiles_storage.url,   # 模板出现static,调用url函数
        'url':reverse                       # 模板出现url,调用reverse函数
    })
    return env                              # 返回修改后的环境变量

3.修改setting中TEMPLATES配置

TEMPLATES = [
    {	# 将django模板引擎修改为jinja2
        'BACKEND': 'django.template.backends.jinja2.Jinja2'     
        ,
        # 模板目录名可根据需求修改,但修改后的模板目录名必须存在
        'DIRS': [os.path.join(BASE_DIR, 'jinja_templates')]     
        ,
        'APP_DIRS': True,
        'OPTIONS': {
        	# 添加已修改过的环境变量
            'environment':'Zero.jinja_env.environment',         
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

WSGI_APPLICATION = 'Zero.wsgi.application'

4.注释使用django原模板的admin应用及路由
注意:一定要注释该应用及其url路由,否则会报错: (admin.E403)(红色) A’django.template.backends.django.DjangoTemplates’ instance must be configured in TEMPLATES in order to use the admin application
在这里插入图片描述

 

 5.配置urls路由及view视图函数

eg:先应用urls

from django.urls import path
from app import views

urlpatterns = [
    path('',views.index)
]

项目url

from django.urls import path, include

urlpatterns = [
    # path('admin/', admin.site.urls),
    path(r'^',include('app.urls'))#这里项目名是app
]

views:

from django.shortcuts import render

# Create your views here.
def index(request):
    return render(request,'index.html')

6.测试模板

.浏览器测试

### 安装与配置Jinja2作为Django默认模板引擎 #### 修改`settings.py` 为了使Django能够识别并使用Jinja2作为其默认模板引擎,在项目的`settings.py`文件中需调整`TEMPLATES`设置。具体来说,应移除或注释掉原有的BACKEND配置项,并替换为指向Jinja2的路径[^1]。 ```python TEMPLATES = [ { 'BACKEND': 'django.template.backends.jinja2.Jinja2', 'DIRS': [], 'APP_DIRS': True, 'OPTIONS': {}, }, ] ``` #### 安装必要的库 确保已安装了最新的Jinja2包版本。可以通过命令行执行如下pip指令完成安装操作: ```bash pip install jinja2 ``` 此过程会自动下载并安装所需依赖项,从而允许Django项目利用更强大的语法特性以及性能优化功能[^3]。 #### 创建视图函数和路由映射 定义一个新的视图方法用于展示由Jinja2解析后的HTML文档内容;接着更新URLconf以便于浏览器可以请求到该资源。下面是一个简单的例子说明如何实现这一点[^2]: ```python from django.shortcuts import render def go_jinja2(request): context = {'message': "Hello from Jinja2!"} return render(request, 'jinja2_home.html', context) ``` 同时还需要编辑对应的urls.py文件添加相应的path记录: ```python from .views import go_jinja2 urlpatterns = [ ... path('go_jinja2/', go_jinja2, name='go_jinja2'), ] ``` #### 构建HTML页面 最后一步是在templates目录内创建名为`jinja2_home.html`的新文件,编写一些基本标记语言代码来验证整个流程是否正常工作。例如: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Jinja2 Example</title> </head> <body> <h1>{{ message }}</h1> <p>This page was rendered using the Jinja2 template engine.</p> </body> </html> ``` 当一切准备就绪之后启动开发服务器并通过浏览器访问/go_jinja2/即可看到预期效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老板来片烤面包

君子博学于文,赠之以礼,谢君~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值