3

我刚刚开始使用 Django-Filer,我对如何实际引用管理系统中上传的图像有点迷茫。

我需要在一个页面上显示一个简单的动态画廊,可以处理多个专辑。每个相册都是页面上的一个新标题,该相册中的所有图像都显示在该标题下。我希望在 Django-Filer 的管理系统中使用的粗略结构是:

    • 图片库
      • 专辑 1
        • 图 1
        • 图 2
        • 图 3
      • 专辑 2
    • 另一个画廊

所以我的问题是,使用模板中的循环,我将如何使用相册文件夹作为新标题来显示每个图像?

第二个相关问题是:如何在不破坏其任何功能的情况下扩展文件夹模型以包含描述字段?

4

1 回答 1

1

这就是我所做的,也许它会对一些调整有所帮助(你的第一个问题)。

首先我在文件管理器中创建文件夹(里面可以有子文件夹)。

之后,我为画廊中我想要的每个文件夹添加新的 FoldersModel。您必须添加“图片库”和“另一个库”文件夹。

模型.py

from filer.fields.folder import FilerFolderField

class FoldersModel(models.Model):
    folder = FilerFolderField()

视图.py

from django.shortcuts import render
from models import FoldersModel

def show(request):
    all_folders = FoldersModel.objects.all()

    return render(request, 'main.html', {'all_folders': all_folders})

main.html

{% load thumbnail %}

    {% for f in all_folders %}

    <div class="title">{{ f.folder }}</div>

    {% for img in f.folder.files %}
    <!-- show files from folder -->
        <img src='{% thumbnail img 200x200 crop=scale %}'/>
    {% endfor %}

    {% for subfolder in f.folder.get_children %}
    <!-- getting all subfolders -->
        <div class="title">{{ subfolder }}</div>

        {% for img in subfolder.files %}
        <!-- show files from subfolder -->
        <img src='{% thumbnail img 200x200 crop=scale %}'/>
        {% endfor %}
    {% endfor %}

{% endfor %}

我不确定这是否是最好的方法,但对我有用。

编辑:
我认为最好使用这个: https ://django-filebrowser.readthedocs.io/en/latest/filelisting.html

于 2016-10-25T14:04:50.647 回答