mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #2568 -- Added documentation for the permalink() decorator. Based on a
patch from Joeboy. git-svn-id: http://code.djangoproject.com/svn/django/trunk@4535 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -1721,11 +1721,30 @@ But this template code is good:: | |||||||
|  |  | ||||||
|     <a href="{{ object.get_absolute_url }}">{{ object.name }}</a> |     <a href="{{ object.get_absolute_url }}">{{ object.name }}</a> | ||||||
|  |  | ||||||
| (Yes, we know ``get_absolute_url()`` couples URLs to models, which violates the | ``permalink`` | ||||||
| DRY principle, because URLs are defined both in a URLconf and in the model. | ------------- | ||||||
| This is a rare case in which we've intentionally violated that principle for |  | ||||||
| the sake of convenience. With that said, we're working on an even cleaner way | ** New in Django development version. ** | ||||||
| of specifying URLs in a more DRY fashion.) |  | ||||||
|  | The problem with the way we wrote ``get_absolute_url()`` above is that it | ||||||
|  | slightly violates the DRY principle: the URL for this object is defined both | ||||||
|  | in the URLConf file and in the model. | ||||||
|  |  | ||||||
|  | You can further decouple your models from the URL configuration using the | ||||||
|  | ``permalink`` function. This function acts as a decorator and is passed the | ||||||
|  | view function and any parameters you would use for accessing this instance | ||||||
|  | directly. Django then works out the correct full URL path using the URL | ||||||
|  | configuration file. For example:: | ||||||
|  |  | ||||||
|  |     from django.db.models import permalink | ||||||
|  |  | ||||||
|  |     def get_absolute_url(self): | ||||||
|  |         return ('people.views.details', str(self.id)) | ||||||
|  |     get_absolute_url = permalink(get_absolute_url) | ||||||
|  |  | ||||||
|  | In this way, you are tying the model's absolute URL to the view that is used | ||||||
|  | to display it, without repeating the URL information anywhere. You still use | ||||||
|  | the ``get_absolute_url`` method in templates, as before. | ||||||
|  |  | ||||||
| Executing custom SQL | Executing custom SQL | ||||||
| -------------------- | -------------------- | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user