<ul> {% for category in categories %} <li><a href="### param ###">{{ category.name }}</a></li> {% endfor %} </ul>
というループの中にリンクがあり、paramには
?category=category.pk
という値が入り、もしこの状態で
<ul> {% for location in locations %} <li><a href="### param ###">{{ location.name }}</a></li> {% endfor %} </ul>
のリンクをクリックすると
?category=category.pk&location=location.pk
また、もし?category=category.pkがない状態で上記リンクをクリックすると
?location=location.pk
といった具合に動的にクエリーの部分を変化させたいのですが、
例えばこれが<li>タグではなく<input type=checkbox>なら自動的に&が付与されてクエリが生成されますが、どうしても<li>タグで実現したいのですが、どのような方法がありますか?
理想としては
<ul> {% for category in categories %} <li><a href="{{ custom:category.pk }}">{{ category.name }}</a></li> {% endfor %} </ul> <ul> {% for location in locations %} <li><a href="{{ custom:location.pk }}">{{ location.name }}</a></li> {% endfor %} </ul>
のようなカスタムテンプレートタグ?を作って(ごめんなさい、ちゃんとした使い方がわからないので適当な表記です)、
もし<li><a href="{{ custom:category.pk }}">{{ category.name }}</a></li>
をクリックしたときにURLになんのパラメーターも含まれていない場合は単純に?category=category.pk
を付与し、もしすでに含まれていたならその後ろに&を付け加えて?category=category.pk&location=location.pk
、そしてもし何もない状態でcategoryではなくlocationをクリックした場合には?location=location.pk
を実現するのはどうかなと思ったのですが・・・
もしカスタムテンプレートタグでこのようなことが実現可能ならご教授お願いします。
逆にこれ以外にもっとかんたんにこの仕組を実装できる方法があるのならそちらもお願い致します。
viewでは
def index(request): categories = Category.objects.all() locations = Location.objects.all() posts = Post.objects.all() category = request.GET.get(key='category', default='') location = request.GET.get(key='category', default='') if category: posts = Post.objects.filter(category__pk=category) c = { 'categories': categories, 'posts': posts, } return render(request, 'classifieds/index.html', c)
と試験的に記述していて雑になっていますが参考までに載せときます。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。