使用Django Logic基于url和slug添加CSS类

时间:2017-01-11 03:03:16

标签: html css django slug

我现在拥有的:

一个带博客部分的简单个人网站。当我从导航栏转到不同的列表项时,它会添加一个"激活"如果li是活动的,则为class。我的博客部分出现了这个问题。

我想要实现的目标:

添加"激活"当我在博客部分和博客帖子中时,所以链接将被激活。我使用slug作为我的帖子网址。

我现在所拥有的并且它不起作用:

template.html

<li class="{% if request.resolver_match.url_name == "index" %}activate{% endif %}"><a href='/'>Home</a></li>
<li class="{% if request.resolver_match.url_name == "blog" %}activate{% endif %}"><a href='/blog/'>Blog</a></li>
<li class="{% if request.resolver_match.url_name == "photohraphy" %}activate{% endif %}"><a href='/photography/'>Photography</a></li>

models.py

from django.db import models
from django.core.urlresolvers import reverse

class Post(models.Model):
    title = models.CharField(max_length=250)
    slug = models.SlugField(max_length=250)
    body = models.TextField()
    date = models.DateTimeField()
    updated = models.DateTimeField(auto_now=True)

    def get_absolute_url(self):
        return reverse('blog:post_detail', args=[self.slug])


    def __str__(self):
        return self.title

urls.py

from django.conf.urls import url, include
from django.views.generic import ListView, DetailView
from blog.models import Post
from . import views

urlpatterns = [
    url(r'^$', views.list_of_post, name='list_of_post'),
    url(r'^(?P<slug>[-\w]+)/$', views.post_detail, name='post_detail')

views.py

from django.shortcuts import render, get_object_or_404
from .models import Post

def list_of_post(request):
    post = Post.objects.all()
    template = 'blog/blog.html'
    context = {'post': post}
    return render(request, template, context)

def post_detail(request, slug):
    post = get_object_or_404(Post, slug=slug)
    template = 'blog/post.html'
    context = {'post': post}
    return render(request, template, context)

我知道我必须在li类中添加一些Jinja逻辑,但我不知道如何正确设置它。我想这与get_absolute_url有关。有人可以建议一种简单而正确的方法吗?

1 个答案:

答案 0 :(得分:0)

我假设所有页面都是在没有ajax调用的情况下呈现的。在这种情况下,无论您呈现的是哪个页面,只要在for eg. return self.render_to_response({'page': 'index'}) url呈现的页面index,就可以简单地传递该页面的名称。然后在模板中,您可以使用简单的if条件并设置激活的类。例如。

<li class="{% if page == "index" %}activate{% endif %}"><a href='/'>Home</a></li>
<li class="{% if page == "blog" %}activate{% endif %}"><a href='/blog/'>Blog</a></li>
<li class="{% if page == "photography" %}activate{% endif %}"><a href='/photography/'>Photography</a></li>