Thank you so much Briel. Really you gave me a nice explanation and the same think i was thinking but was not able to make understand to my senior. let me put your idea to my senior and lets see what they say.. but really i appreciate you and for your politeness.
On Jan 8, 6:43 pm, Briel <toppe...@gmail.com> wrote: > Hi Praveen > I personally would prefer naming the urls rather than using the > get_absolute_url. > Both can accomplish your goal, but naming the urls is a more robust > and in other ways a better solution. > > If you in a week decide that the url should not be /category/... but > instead /whatever/... you would have to recode your get_absolute_url > method. However, if you use the names in urls, everything would still > work after changing the urls. The reason is that when using the name > of an url, Django will find what the absolute url will be given the > args you use, in your example the id. > In a way, you could say that when using named urls, django is both > writing and running get_absolute_url for you. > > Another plus when using named urls, is that you can give your urls > name that give meaning. That will make it a lot easier to understand > what's going on in the template when you read your own code 6 months > from now. Especially if you have several views of one model. > > Say you had a model for blog posts. > Then you might want to have an url for your own blogs, another one for > your friend's blogs ect. You could still use get_absolute_url, but > this time, it would be harder to make and use, as you now would need > to know what url to get. Also when reading the template it would be > hard to see which url is being displayed. Instead using tags like > {% url friends_blog args=x %} > {% url your_blog args=x %} > {% url all_blog args=x %} > would be easy to understand after not working with the code for a long > time. > > -Briel > > > > Praveen wrote: > > Hi Briel i am totally confused now. > > My senior told me to write get_absolute_url > > > so i wrote get_absolute_url like this > > class Listing_channels(models.Model): > > list_channel = models.CharField(max_length = 20) > > visibility = models.BooleanField() > > > def __unicode__(self): > > return self.list_channel > > > def get_absolute_url(self): > > return u'/category/listing_view/%i/' % self.id > > > and in html template i am calling > > > {%if listing_result %} > > {% for n in listing_result %} > > <li> <a href="{{n.get_absolute_url}}">{{n.list_channel}}</a></ > > li> > > {% endfor %} > > {% else %} > > <p>not available</p> > > {% endif %} > > </ul> > > > so its working fine. > > > so now i have two mechanism one is your as you told me to write and > > second one is > > get_absolute_url() function. > > > Now my confusion is if we have another same class event_channel and > > event and many more classes like this then i will have to write > > get_absolute_url() for each class > > and if go with you then there i need to change only in urls.py that i > > think fine. > > > so i should go with get_absolute_url? give me the best and solid > > reason so i could make understand to senior, and you know the senior > > behave.. > > > Briel wrote: > > > > Using urls with names will solve your problem. > > > > Basically if you change your urls.py like this: > > > > url( > > > r'^category/listing_view/(?P<id>\w+)/$', > > > 'mysite.library.views.listing_view', > > > name = 'name_for_this_view' > > > ), > > > > What I have done is to add a name to the url for convenience I also > > > used the url() function. This name can now be used instead of the link > > > to your view. So if you were to change the site structure, when > > > changes would be made to your urlconf, django would then be able to > > > figure things out for you. In this version your new link would look > > > like this: > > > > <li><a href=" > > > {% url name_for_this_view n.id %} > > > ">{{n.list_channel}}</a></li> > > > > In the docs you can read about it at > > > url():http://docs.djangoproject.com/en/dev/topics/http/urls/#url > > > naming:http://docs.djangoproject.com/en/dev/topics/http/urls/#id2 > > > > Good luck. > > > -Briel > > > > On 8 Jan., 12:41, Praveen <praveen.python.pl...@gmail.com> wrote: > > > > Hi Malcolm i am very new bie of Django. i read through > > > > get_absolute_url but do not know how to use. > > > > What you have given the answer i tried with that and its working fine > > > > but my senior asked me what will happen if i change the site name then > > > > every where you will have to change url > > > > mysite.library.views.listing_view. > > > > > so they told me to use get_absolute_url > > > > > i wrote get_absolute_ul in models.py > > > > def get_absolute_url(self): > > > > return "/listing/%i/" % self.id > > > > and i am trying to use in my html page template but i don't know how > > > > to use > > > > > <li> <a href="{{get_absolute_url}}{{n.id}}">{{n.list_channel}}</a></ > > > > li> > > > > > then again same problem. first time when some one click on link it > > > > works fine but second time it appends the link > > > > likehttp://127.0.0.1:8000/category/listing_view/3/3 > > > > > Please give me some idea > > > > > On Jan 8, 3:37 pm, Praveen <praveen.python.pl...@gmail.com> wrote: > > > > > > Thank you so much Malcolm. > > > > > every one gives only the link and tell to read but your style of > > > > > solving the problem is amazing. how you explained me in a nice way > > > > > that i can never ever find in djangoproject.com. > > > > > Thanks you so much malcom > > > > > > On Jan 8, 3:23 pm, Malcolm Tredinnick <malc...@pointy-stick.com> > > > > > wrote: > > > > > > > I'm going to trim your code to what looks like the relevant portion > > > > > > of > > > > > > the HTML template, since that's where the easiest solution lies. > > > > > > > On Thu, 2009-01-08 at 02:02 -0800, Praveen wrote: > > > > > > > [...] > > > > > > > > list_listing.html > > > > > > > > <div id="leftpart"> > > > > > > > <h3>Sight Seeings</h3> > > > > > > > <ul> > > > > > > > {%if listing_result %} > > > > > > > {% for n in listing_result %} > > > > > > > <li><a href="{{n.id}}">{{n.list_channel}}</a></li> > > > > > > > {% endfor %} > > > > > > > {% else %} > > > > > > > <p>not available</p> > > > > > > > {% endif %} > > > > > > > </ul> > > > > > > > </div> > > > > > > > [...] > > > > > > > > I am displaying Listing_channels and Listing on same page. if > > > > > > > some one > > > > > > > click on any Listing_channels the corresponding Listing must > > > > > > > display > > > > > > > on same page. that is why i am also sending the Listing_channels > > > > > > > object to list_listing.html page. if some one click first time on > > > > > > > Listing_channels it shows the > > > > > > > urlhttp://127.0.0.1:8000/category/listing_view/1/ > > > > > > > but second time it appends 1 at the end and the url becomes > > > > > > >http://127.0.0.1:8000/category/listing_view/1/1 > > > > > > > The above code fragment is putting an element in the template that > > > > > > looks > > > > > > like > > > > > > > <a href="1">...</a> > > > > > > > That is a relative URL reference and will be relative to the URL of > > > > > > the > > > > > > current page (which is .../category/listing_view/1/). In other > > > > > > words, it > > > > > > will be appended to that URL. One solution is to change the relative > > > > > > reference to look like > > > > > > > <a href="../1">...</a> > > > > > > > or, in template language: > > > > > > > <li><a href="../{{n.id}}">{{n.list_channel}}</a></li> > > > > > > > That assumes you will only be displaying this template > > > > > > as ..../listing_view/1/ (or with a different number as the final > > > > > > component), since it will *always* remove the final component and > > > > > > replace it with the id value. > > > > > > > The alternative, which is a little less fragile, is to use the "url" > > > > > > template tag to include a URL that goes all the way back to the > > > > > > hostname > > > > > > portion. You could write > > > > > > > <li><a href=" > > > > > > {% url mysite.library.views.listing_view n.id %} > > > > > > ">{{n.list_channel}}</a></li> > > > > > > > (I've put in some line breaks just to avoid unpleasant > > > > > > line-wrapping). > > > > > > The {% url ... %} portion will return "/category/listing_view/1/" > > > > > > -- or > > > > > > whatever the right n.id value is -- which will always be correct. > > > > > > > Have a read > > > > > > ofhttp://docs.djangoproject.com/en/dev/ref/templates/builtins/#urlif > > > > > > you're not familiar with the URL tag. > > > > > > > Regards, > > > > > > Malcolm --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-users@googlegroups.com To unsubscribe from this group, send email to django-users+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/django-users?hl=en -~----------~----~----~----~------~----~------~--~---