自動化無しに生活無し

WEB開発関係を中心に備忘録をまとめています

【Django】FontAwesomeで星のアイコンを使ったレビューの投稿と表示

thumbnail

最終的にこのようになる。

今回はテンプレートのwithとcenterは不使用とした。

そして、5つ星の内、4つ星でレビューした場合、空の星を1つ描画する仕様に仕立てた。

モデル

from django.db import models
from django.core.validators import MinValueValidator,MaxValueValidator


MAX_STAR    = 5

class Review(models.Model):
    comment     = models.CharField(verbose_name="コメント",max_length=500)
    star        = models.IntegerField(verbose_name="星",validators=[MinValueValidator(1),MaxValueValidator(MAX_STAR)])

    def star_icon(self):
        dic                 = {}
        dic["true_star"]    = self.star * " "
        dic["false_star"]   = (MAX_STAR - self.star) * " "

        return dic

MinValueValidatorとMaxValueValidatorを使用して1~5までの数値のみを格納できるようにしている。

その上で、星のアイコンを表示する際、★の描画はtrue_starで、☆の描画はfalse_starを返すようにしている。

テンプレート

{% for review in reviews %}
<div class="border">
    <div>{{ review.comment }}</div>
    <div class="review_star">
        <span class="review_true_star">{% for s in review.star_icon.true_star %}<i class="fas fa-star"></i>{% endfor %}</span>
        <span class="review_false_star">{% for s in review.star_icon.false_star %}<i class="far fa-star"></i>{% endfor %}</span>
    </div>
</div>
{% endfor %}

star_iconメソッドを発動させ、true_star及びfalse_starを描画している。

参照

ソースコード

https://github.com/seiya0723/bbs_review

スポンサーリンク