【Python】Django Grappelli:打造优雅且现代化的 Django 管理后台

news2025/1/19 7:57:22

在这里插入图片描述

在 Django 开发中,默认的 Django Admin 界面尽管功能强大且能满足大多数管理需求,但其界面设计相对基础,尤其在用户体验和视觉呈现上显得较为简约。在一些项目中,开发者可能需要更加现代化且美观的后台界面。这时,Django Grappelli 就成为了一个理想的选择。

Django Grappelli 是一个用于增强 Django Admin 界面的第三方库,它不仅为 Django 提供了更时尚的用户界面,还扩展了许多功能,使后台管理变得更加高效和易用。在本文中,我们将详细介绍 Django Grappelli 的安装、功能特性、定制化能力以及如何在项目中集成它来提升 Django 管理后台的体验。

在这里插入图片描述
华丽的分割线

⭕️宇宙起点

    • 🎬 什么是 Django Grappelli?
    • 📦 安装与配置
      • 配置 URL
    • 🔨 Grappelli 的核心功能
      • 1. 现代化、响应式的用户界面
      • 2. 内嵌对象管理
      • 3. 过滤和排序增强
      • 4. 无缝集成 Django Filebrowser
      • 5. 更直观的多语言支持
      • 6. 丰富的自定义选项
    • ♨️ 实践:通过 Grappelli 优化 Django 项目
      • 1. 安装和配置
      • 2. 在 Admin 中注册模型
      • 3. 自定义 Grappelli 样式
    • 🥇 使用 Grappelli 的好处
    • 📥 下载地址
    • 💬 结语
    • 📒 参考文献


标题1

🎬 什么是 Django Grappelli?

在这里插入图片描述

Django Grappelli 是一个美化和增强 Django Admin 界面的应用扩展,它通过集成现代化的 UI 组件和高级功能,使 Django 的默认后台管理界面更加美观、友好。Grappelli 在原生 Django Admin 的基础上加入了如下特性:

  • 现代化的管理界面:Grappelli 提供了基于 Bootstrap 的响应式界面,极大地提升了用户体验。
  • 内嵌对象支持:Grappelli 允许用户在后台更轻松地管理嵌套的对象。
  • 支持 Django Filebrowser:它可以无缝集成 Django Filebrowser,提供文件和媒体的管理功能。
  • 更强的搜索和过滤功能:增强了数据表格的搜索、过滤和排序功能,使得对数据的管理更加高效。

标题2

📦 安装与配置

要在 Django 项目中使用 Grappelli,你需要先通过 pip 安装该库:

pip install django-grappelli

安装完成后,接下来需要将 Grappelli 添加到 Django 项目的 INSTALLED_APPS 中:

# settings.py

INSTALLED_APPS = [
    'grappelli',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    # 你的其他应用
]

Grappelli 必须添加在 django.contrib.admin 之前,确保它正确覆盖默认的 Django Admin 样式。

配置 URL

在配置完 INSTALLED_APPS 之后,你还需要在项目的 urls.py 文件中添加 Grappelli 的 URL 路由:

# urls.py

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('grappelli/', include('grappelli.urls')),  # 这是 Grappelli 的 URL 配置
    path('admin/', admin.site.urls),  # Django Admin 的 URL 配置
]

这样,你可以通过 /grappelli/ 访问 Grappelli 的后台管理界面。配置完成后,运行 Django 开发服务器,并访问 /admin/,你将看到一个焕然一新的 Django Admin 界面。


标题3

🔨 Grappelli 的核心功能

Grappelli 不仅仅是一个美化工具,它还提供了很多增强的功能,使得管理后台更具灵活性和可操作性。下面,我们将介绍 Grappelli 的几个核心功能。

1. 现代化、响应式的用户界面

Grappelli 最大的特点就是它现代化的用户界面。相比于默认的 Django Admin,Grappelli 提供了更加整洁的布局、更清晰的排版和更友好的用户体验。通过使用响应式的设计,它能够在桌面端和移动端设备上都保持良好的展示效果。

Grappelli 的设计风格基于 Bootstrap,支持自适应布局,界面元素更符合现代网页设计的趋势,适合那些希望在后台展示数据时有更好视觉效果的应用场景。

2. 内嵌对象管理

Django 默认的内联表单(Inline Forms)虽然能处理一对多或多对多的关系,但在展示嵌套数据时显得不够直观。Grappelli 通过改进内联表单的展示方式,让嵌套对象的管理更加方便。

例如,当你有一个 Blog 模型和一个评论(Comment)模型时,Grappelli 提供了一个更清晰的界面,允许你直接在编辑 Blog 时管理其关联的评论对象,极大地提升了数据的管理效率。

3. 过滤和排序增强

Grappelli 对于数据表格的过滤和排序功能进行了增强。在默认的 Django Admin 中,虽然提供了基本的过滤选项,但 Grappelli 允许你对数据进行更细致的过滤和排序。例如,Grappelli 提供了下拉菜单、多选框等更加丰富的过滤选项,帮助你在大数据集里更高效地找到目标数据。

此外,Grappelli 还支持表格中的批量操作,可以一次性对多个记录进行编辑、删除等批处理操作。

4. 无缝集成 Django Filebrowser

如果你的应用涉及到文件或图片的管理,Grappelli 可以与 Django Filebrowser 无缝集成。Filebrowser 是一个用于文件和图片管理的 Django 扩展,提供了类似文件管理器的界面,允许用户上传、删除、重命名文件等操作。

通过集成 Filebrowser,Grappelli 可以让你在后台管理文件和媒体资源,并提供了直观的文件上传和浏览界面,非常适合博客、内容管理系统等应用。

5. 更直观的多语言支持

Grappelli 提供了更加直观的国际化支持。如果你的项目需要支持多语言,Grappelli 可以自动处理后台的翻译。管理员用户可以根据需要切换不同的语言,查看和管理内容。这对多语言项目尤其有用。

6. 丰富的自定义选项

Grappelli 不仅仅是一个现成的 UI,它还提供了丰富的自定义选项。你可以通过自定义模板、CSS、JS 来扩展 Grappelli 的功能,甚至可以根据需求完全定制管理界面。

例如,你可以通过在 static 文件夹中添加自定义的 CSS 来修改 Grappelli 的默认样式:

{% block extrahead %}
<link rel="stylesheet" type="text/css" href="{% static 'css/custom.css' %}">
{% endblock %}

通过这种方式,你可以在保留 Grappelli 的基本功能的基础上,打造一个符合自己项目需求的管理界面。


标题4

♨️ 实践:通过 Grappelli 优化 Django 项目

假设你正在开发一个博客应用,并希望通过 Grappelli 来优化管理后台,以下是如何集成 Grappelli 和优化后台管理的步骤。

1. 安装和配置

我们已经介绍了如何安装和配置 Grappelli,你可以参考上面的步骤完成基本的安装。接下来,我们将展示如何为 Blog 应用进行配置。

首先,定义你的博客模型(Model):

# models.py

from django.db import models

class Blog(models.Model):
    title = models.CharField(max_length=200)
    content = models.TextField()
    created_at = models.DateTimeField(auto_now_add=True)
    
    def __str__(self):
        return self.title

class Comment(models.Model):
    blog = models.ForeignKey(Blog, on_delete=models.CASCADE)
    content = models.TextField()
    created_at = models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return self.content[:20]

在这个示例中,Blog 模型包含博客的标题和内容,而 Comment 模型用于存储博客的评论。

2. 在 Admin 中注册模型

接下来,在 admin.py 中注册你的模型,并使用 Grappelli 提供的增强功能:

# admin.py

from django.contrib import admin
from .models import Blog, Comment

class CommentInline(admin.TabularInline):
    model = Comment
    extra = 1

class BlogAdmin(admin.ModelAdmin):
    list_display = ('title', 'created_at')
    search_fields = ('title',)
    inlines = [CommentInline]

admin.site.register(Blog, BlogAdmin)

说明:

  • 我们定义了一个内联表单 CommentInline,这样可以在博客编辑界面直接管理评论。
  • list_displaysearch_fields 是 Django Admin 的标准功能,Grappelli 会增强它们的可用性,提供更好看的 UI 和体验。

3. 自定义 Grappelli 样式

你可以通过修改 Grappelli 的样式,让后台界面符合你的品牌或项目需求。只需在 static/css/custom.css 文件中编写自定义样式,并在模板中引入它即可。

/* static/css/custom.css */

body {
    background-color: #f8f9fa;
}

h1 {
    font-family: 'Arial', sans-serif;
}

标题5

🥇 使用 Grappelli 的好处

使用 Django Grappelli

能带来许多好处,尤其是对于需要更现代化、更直观管理后台的项目。以下是使用 Grappelli 的几个主要好处:

  1. 提升用户体验:Grappelli 提供了更加美观的 UI 设计,用户能够更快速、更直观地进行数据操作和管理。

  2. 提高开发效率:通过 Grappelli,你可以减少对管理界面的样式定制和功能扩展工作。Grappelli 提供了许多开箱即用的增强功能,如文件管理、内嵌对象等。

  3. 易于定制:Grappelli 支持丰富的自定义能力,开发者可以通过 CSS、模板和 JavaScript 对其进行深度定制,打造完全符合项目需求的管理后台。

  4. 无缝集成:Grappelli 与 Django Admin 无缝集成,不需要大幅度修改现有项目代码即可使用,升级和维护成本也相对较低。


标题6

📥 下载地址


Django Grappelli 最新版 下载地址


标题7

💬 结语

Django Grappelli 是一个非常优秀的 Django 扩展库,它通过美化和增强 Django Admin 界面,让开发者能够在不牺牲 Django Admin 强大功能的情况下,提供一个现代化且用户友好的后台管理系统。Grappelli 具有良好的扩展性、丰富的 UI 元素,并支持内嵌对象、文件管理、批量操作等高级功能。

通过 Grappelli,开发者可以轻松定制一个美观且功能丰富的管理界面,并且能够通过简单的配置集成到任何 Django 项目中。如果你正在开发需要管理后台的 Django 应用,不妨尝试一下 Grappelli,相信它能极大地提升你项目的用户体验和开发效率。


标题8

📒 参考文献

  • Django Grappelli 官网
  • Django Grappelli GitHub仓库

TheEnd


在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2175917.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

轻松映射 JavaBean 属性:Hutool BeanUtils 的 toBean 方法使用体验分享

欢迎点点关注&#xff1a;程序猿方&#xff0c;会不定期分享实用技术文章&#xff0c;共同探讨编程魅力&#xff01; BeanUtils中create()的使用 我们在编程过程中&#xff0c;一个JavaBean对象通常包含了大量的属性&#xff0c;需要把数据库查询的Entity数据&#xff0c;映射…

5.使用 VSCode 过程中的英语积累 - Go 菜单(每一次重点积累 5 个单词)

前言 学习可以不局限于传统的书籍和课堂&#xff0c;各种生活的元素也都可以做为我们的学习对象&#xff0c;本文将利用 VSCode 页面上的各种英文元素来做英语的积累&#xff0c;如此做有 3 大利 这些软件在我们工作中是时时刻刻接触的&#xff0c;借此做英语积累再合适不过&a…

大模型推理任务Nvidia GPU选型指南

大型语言模型 (LLM)&#xff08;如 GPT-4、BERT 和其他基于 Transformer 的模型&#xff09;彻底改变了 AI 格局。这些模型需要大量计算资源来进行训练和推理。选择合适的 GPU 进行 LLM 推理可以极大地影响性能、成本效益和可扩展性。 在本文中&#xff0c;我们将探索最适合 L…

【开源免费】基于SpringBoot+Vue.JS美容院管理系统(JAVA毕业设计)

博主说明&#xff1a;本文项目编号 T 055 &#xff0c;文末自助获取源码 \color{red}{T055&#xff0c;文末自助获取源码} T055&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析…

pcs集群表决盘故障导致主机reboot

建议重建fence设备并配置 PCSOracle HA实战安装配置参考 - 墨天轮

Bluetooth Core 6.0中以Central设备发起Channel Sounding详细流程介绍

当BLE设备间完成连接后&#xff0c;由发起态进入连接态的设备被称为Central device&#xff0c;而由广播态进入连接态的设备被称为peripheral device。当双方设备按照Vol 6, Part D&#xff1a;6.34 Channel Sounding setup phase完成BLE CS的设置后&#xff0c;双方就可以发起…

QT界面制作

作业 1> 创建一个新项目&#xff0c;将默认提供的程序都注释上意义 pro文件 QT core gui #引入类库 core&#xff0c;gui greaterThan(QT_MAJOR_VERSION, 4): QT widgets #超过版本4会加上widgetsCONFIG c11 #支持c11新特性# The following define makes your …

第二节—类与对象(上)

1.面向过程和面向对象初步认识 C语言是面向过程的&#xff0c;关注的是过程&#xff0c;分析出求解问题的步骤&#xff0c;通过函数调用逐步解决问题。 C是基于面向对象的&#xff0c;关注的是对象&#xff0c;将一件事情拆分成不同的对象&#xff0c;靠对象之间的交互完成 2.…

Java中的哈希函数

在Java的世界里&#xff0c;哈希函数是一个核心概念&#xff0c;它不仅在数据结构中扮演着重要角色&#xff0c;如哈希表&#xff08;HashMap、HashSet等&#xff09;&#xff0c;还在安全领域&#xff0c;如密码存储和消息摘要中发挥着至关重要的作用。本文将深入探讨Java中的…

千兆网络变压器HX84801SP POE应用主板

千兆网络变压器HX84801SP POE应用主板&#xff1a; 随着网络时代科技飞速发展&#xff0c;2G到5G时代短短10年实现了目标。 千兆POE交换机是一种高速网络设备&#xff0c;适用于各种网络环境&#xff0c;尤其是需要高带宽和快速数据传输的场合。 千兆网络变压器POE交换机通常采…

HTML基础用法介绍二

目录&#xff1a; 列表 无序列表有序列表定义列表 表格 表格单元格合并 input标签 属性值text和password的使用 输入框中占位文本的使用 属性值radio的使用属性值checkbox的使用属性值file的使用 下拉菜单 文本域 label标签 字符实体 &#x1f698;正片开始 无序列表 …

手机/平板端 Wallpaper 动态壁纸文件获取及白嫖使用指南

Wallpaper 动态壁纸文件获取及使用指南 目录 壁纸文件获取手机 / 平板使用手机 / 平板效果预览注意事项PC/Mac 使用 1. 壁纸文件获取链接 链接&#xff1a;夸克网盘分享 复制链接到浏览器打开并转存下载即可。 &#xff08;主页往期视频的 4K 原图和 mpkg 动态壁纸文件&#xf…

IO端口与IO接口

I/O端口和I/O接口是计算机系统中用于连接外部设备的关键组成部分&#xff0c;两者密切相关&#xff0c;但又有明显的区别&#xff1a; I/O端口 (I/O Port): 定义: I/O端口是内存地址空间中的一组特殊地址&#xff0c;用于与外部设备进行数据交换。CPU通过向这些特定的地址写入…

【C语言】单片机map表详细解析

1、RO Size、RW Size、ROM Size分别是什么 首先将map文件翻到最下面&#xff0c;可以看到 1.1 RO Size&#xff1a;只读段 Code&#xff1a;程序的代码部分&#xff08;也就是 .text 段&#xff09;&#xff0c;它存放了程序的指令和可执行代码。 RO Data&#xff1a;只读…

MQ基础:RabbitMQ真面目

同步调用方式&#xff0c;指的是发送方直接发送给接收方的形式。而这种方式在某些情况下可能出现问题&#xff0c;比如当业务逻辑变得复杂&#xff0c;同步的方式需要等待上一条指令被接收后才会继续&#xff0c;对性能的影响很大。 异步的方式&#xff0c;增加了一个消息代理…

网络编程(12)——完善粘包处理操作(id字段)

十二、day12 之前的粘包处理是基于消息头包含的消息体长度进行对应的切包操作&#xff0c;但并不完整。一般来说&#xff0c;消息头仅包含数据域的长度&#xff0c;但是如果要进行逻辑处理&#xff0c;就需要传递一个id字段表示要处理的消息id&#xff0c;当然可以不在包头传i…

【Godot4.3】简单物理模拟之圆粒子碰撞检测

概述 最近开始研究游戏物理的内容&#xff0c;研究运动、速度、加速度之类的内容。也开始模仿一些简单的粒子模拟。这些都是一些基础、简单且古老的算法&#xff0c;但是对于理解游戏内的物理模拟很有帮助。甚至你可以在js、Python或者其他程序语言中实现它们。 图形的碰撞检…

Linux操作系统中SpringGateway

1、SpringGateway简介 核心功能有三个&#xff1a; 路由&#xff1a;用于设置转发地址的 断言&#xff1a;用来判断真实应该请求什么地址 过滤器&#xff1a;可以过滤地址和处理参数 1、什么是网关 网关是后台服务的统一入口&#xff0c;类似于平时网络里提到的网关。 2…

ppt压缩有什么简单方法?压缩PPT文件的几种方法

ppt压缩有什么简单方法&#xff1f;许多用户常常面临文件过大的问题&#xff0c;尤其在需要通过电子邮件发送或上传至网络平台时&#xff0c;大文件会带来诸多麻烦。此外&#xff0c;较大的文件可能导致软件响应缓慢&#xff0c;从而影响整体的演示体验。因此&#xff0c;寻找有…

ESP8266/01s模块烧录MQTT AT固件篇

&#xff08;代码完美实现&#xff09;stm32 新版 onenet mqtt物联网(保姆级教程) 地址&#xff1a; &#xff08;代码完美实现&#xff09;stm32 新版 onenet mqtt物联网(保姆级教程)https://blog.csdn.net/Wang2869902214/article/details/142501323 乐鑫ESP8266/安信可…