djangoに画像が表示されない

サミャクジャイン

私はこの製品モデルを持っています:

class Product(models.Model):
    category = models.ForeignKey(Category,
                                 related_name='products',
                                 on_delete=models.CASCADE)
    name = models.CharField(max_length=200, db_index=True)
    slug = models.SlugField(max_length=200, db_index=True)
    image = models.ImageField(upload_to='products/%Y/%m/%d',
                              blank=True)
    description = models.TextField(blank=True)
    price = models.DecimalField(max_digits=10, decimal_places=2)
    available = models.BooleanField(default=True)
    created = models.DateTimeField(auto_now_add=True)
    updated = models.DateTimeField(auto_now=True)

    class Meta:
        ordering = ('name',)
        index_together = (('id', 'slug'),)

    def __str__(self):
        return self.name

    def get_absolute_url(self):
        return reverse('shop:product_detail',
                       args=[self.id, self.slug])

そしてproduct_list、すべての製品が表示されるこのビュー:

def product_list(request, category_slug=None):
    category = None
    categories = Category.objects.all()
    products = Product.objects.filter(available=True)
    if category_slug:
        category = get_object_or_404(Category, slug=category_slug)
        products = products.filter(category=category)
    return render(request, 'shop/product/list.html',{
        'category':category,
        'categories':categories,
        'products':products
    })

そしてこれはlist.htmlテンプレートです:

{% extends "shop/base.html" %}
{% load static %}
{% block title %}
{% if category %}{{ category.name }}{% else %}Products{% endif %}
{% endblock %}
{% block content %}
<div id="sidebar">
    <h3>Categories</h3>
    <ul>
        <li {% if not category %}class="selected" {% endif %}>
            <a href="{% url "shop:product_list" %}">All</a>
        </li>
        {% for c in categories %}
        <li {% if category.slug == c.slug %}class="selected" {% endif %}>
            <a href="{{ c.get_absolute_url }}">{{ c.name }}</a>
        </li>
        {% endfor %}
    </ul>
</div>
<div id="main" class="product-list">
    <h1>{% if category %}{{ category.name }}{% else %}Products
        {% endif %}</h1>
    {% for product in products %}
    <div class="item">
        <a href="{{ product.get_absolute_url }}">
            <img src="{% if product.image %}{{ product.image.url }}{%
else %}{% static "img/no_image.png" %}{% endif %}">
        </a>
        <a href="{{ product.get_absolute_url }}">{{ product.name }}</ a>
            <br>
            ${{ product.price }}
    </div>
    {% endfor %}
</div>
{% endblock %}

私が欲しいのは、product_listページにすべての製品が価格、名前、画像とともに表示されることです。画像が表示されないことを除いて、すべてが正常に機能します。どの画像を撮ろうとしても、常にalt画像テキストが表示されます。私が設定しているMEDIA_ROOTMEDIA_URL、私の中にsettings.py

MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media/')

また、imageモデルフィールドで指定されたフォルダも作成され、画像が保存されます。では、どこに問題があるのでしょうか。

リビングルーム

プロジェクトのURLにURL設定を追加する必要があります

ここでそれをチェックしてくださいhttps://docs.djangoproject.com/en/3.1/howto/static-files/#serving-files-uploaded-by-a-user-during-development

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

分類Dev

Djangoの静止画像が表示されない

分類Dev

Django静的メディアに画像が表示されない

分類Dev

画像がウェブページに表示されない(Django)

分類Dev

Django画像タグに写真が表示されない

分類Dev

Django:画像/絶対URLがHTMLに表示されないこと

分類Dev

画像が django テンプレートに表示されない

分類Dev

画像がdjango管理ページに表示されない

分類Dev

TweetImageに画像が表示されない

分類Dev

SVG <画像>がiPhoneに表示されない

分類Dev

Gulpfile画像がCSSに表示されない

分類Dev

JFrameに画像が表示されない

分類Dev

Android画像がimageviewに表示されない

分類Dev

画像がinnerHTML内に表示されない

分類Dev

背景画像がdivに表示されない

分類Dev

JFrameに画像が表示されない

分類Dev

collectionViewに画像が表示されない

分類Dev

背景画像がChromeに表示されない

分類Dev

IconButtonCircleAvatarに画像が表示されない

分類Dev

IconButtonCircleAvatarに画像が表示されない

分類Dev

SwiftUINavigationViewに画像が表示されない

分類Dev

画像がdivに表示されない

分類Dev

QML:contentItemに画像が表示されない

分類Dev

Pythonに画像が表示されない

分類Dev

AndroidGridViewに画像が表示されない

分類Dev

ListViewに画像が表示されない

分類Dev

画像にReactが表示されない

分類Dev

背景画像がHTMLに表示されない

分類Dev

UICollectionViewに画像が表示されない

分類Dev

画像が完全に表示されない

Related 関連記事

ホットタグ

アーカイブ