我试图创建SEO友好的urls,其中所有的空格被替换为连字符。
这就是我如何在Django模板中使用slugify来“解析”URL的方式。
<a href="{% url 'dj' dj_name=dj.name|slugify %}">这是我的urls.py
url(r'^top100/(?P<dj_name>[a-zA-Z0-9 \'&-]+)/$', views.dj, name='dj')这是我的观点
def dj(request, dj_name):
dj = DJ.objects.get(name=dj_name)
dj_song_list = Song.objects.filter(artist=dj, duplicate=False).order_by('-votes', '-release_date')
return render(request, 'hunt/dj.html', {'dj_song_list': dj_song_list, 'dj':dj}现在urls中的%20已更改为-,但我得到了错误DJ matching query does not exist.
这也忽略了DJ名称中的&。例如,它将DJ Above & Beyond的url更改为www.example.com/top100/above-beyond。
发布于 2014-01-27 10:19:12
您正在尝试请求一个对象,其中包含它的段塞,而不是它在数据库中的名称。段塞是一个字符串,根据原始名称计算,您可以在URL中使用它(因为它是SEO友好的)。但是,如果数据库中的任何地方都没有保存这段代码的话,就不能使用它来请求对象。事实上,从鼻涕虫中提取原始名字是不可能的。
Above & Beyond --> above-beyond --> Above @ Beyond }
--> above & beyond } A lot of possibilities...
--> ABOVE - BEYOND }
--> ...您需要使用SlugField()并根据这个新字段获取所需的对象。简短的例子:
class News(models.Model):
title = models.CharField('title', max_length=100)
slug = models.SlugField('slug', max_length=100, unique=True)
content = models.TextField('news content')
def get_absolute_url(self):
return reverse('news-view', args=(self.slug, ))
# In the app/urls.py:
from . import views
urlpatterns = [
url(r'^(?P<slug>.+)/$', view.news_detail, name='news-view'),
#...
]
# In the 'news_detail' view (app/views.py)
news = get_object_or_404(News, slug=slug)实际上,您可以使用templatetags,如果您想使用slugify这样的干净URL :他们使用问题的ID从URL检索内容,但是还有标题,您可以更改它,它无论如何都会重定向您。
http://stackoverflow.com/questions/21377984/using-slugify-in-django-urls
^^^^^^^^
ID used ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
slug just for SEO purpose, not
used to retrieve from the db发布于 2014-01-27 10:16:16
你为什么不在你的模型中使用SlugField()?然后你就可以用你的鼻涕虫来查询了。我想这个错误来自于名字上的查询集,而不是鼻涕虫。
https://stackoverflow.com/questions/21377984
复制相似问题