In urls.py
# urls like "articles/2011/tutorial03" or "articles/2011/tutorial03.html" or "articles/2011/tutorial03.htm"
urlpatterns = patterns('',
(r'articles/(?P<year>\d+)/(?P<item>[^/]+)(?:\.htm(?:l)?)?/?\$', 'articles.detail'),
)
In template:
<p><a href="{% url articles.views.detail article.year article.id %}">The Article</a></p>
- Regular expression is hard to read.
Any change of URL means to change some templates.- Redirect to the prefered URL (e.g. articles/2011/tutorial03.htm -> articles/2011/tutorial03) must developer provide itself.
source: https://docs.djangoproject.com/en/1.3/intro/tutorial03/
In bootstrap.php
$router[] = new Route('articles/<year \d+>/<item>[.htm[l]]', 'Articles:detail');
In template:
<p><a n:href="Articles:detail $article->year, $article->id">The Article</a></p>
- Route mask is easy to read.
- Any change of URL means to change one line in bootstrap.php.
- Redirect to the prefered URL (e.g. articles/2011/tutorial03.htm -> articles/2011/tutorial03) is done automatically.
Littlemaple: Well, "canonical" is IMO usually Model.get_absolute_url variant and non-canonical URIs are domain-specific.
You can run application in non-root uri using url('prefix', include('app.url')), althrough I don't see any relevance to this discussion ;)
BTW, you are not required to use named regexp variant (althrough I'd trade flexibility over readability in this case), and
is imho fairly readable.