xRobot
xRobot

Reputation: 26567

How to save links in TextFields

I have a simple Blog model with a TextField. What is the best way to save links in the TextField ?

1) Saving link in the database in this form: http://www.example.com and then using some filter in the template to trasform it in form:

<a rel="nofollow" href="http://www.example.com>http://www.example.com</a>

2) Saving link in the database directly in this form:

<a rel="nofollow" href="http://www.example.com>http://www.example.com</a>

Upvotes: 3

Views: 3257

Answers (4)

Chris Lawlor
Chris Lawlor

Reputation: 48902

Assuming you are talking about how to save links (or any HTML formatting really) that you are including in your blog posts, not standalone links (like for a blogroll):

You might want to think about adopting some sort of markup language like Markdown or BBCode. You'd then store the blog post in the pure markup syntax, and provide a method (like blog.get_post()) that would parse the stored markup and return HTML. You'd then use the safe filter in your template to avoid escaping the HTML.

Even better, to avoid parsing your markup on every request, cache it in the database. Add a TextField called something like text_html to your Blog model. Override your Blog model's save method to parse the markup into HTML and save the HTML to the text_html field.

Then when you want to render the blog post in a template, you can use {{ post.text_html|safe }} without having to parse your markup each time.

So your Blog model might look like this (only text field shown for clarity)

import markdown

class BlogPost(models.Model):
    text = models.TextField()
    text_html = models.TextField(editable=False) # don't want to see this in Admin

    def save(self, force_insert=False, force_update=False):
        self.text_html = markdown(self.text)
        super(BlogPost, self).save(force_insert, force_update)

To make things simpler on the data entry side, you could also add in a nice javascript editor - like the one I'm typing this answer in right now.

Upvotes: 5

eos87
eos87

Reputation: 9353

use the second alternative, and after use safe to escape html code

Upvotes: 0

Olivier Verdier
Olivier Verdier

Reputation: 49146

You could use a URL field (or a TextField, of course) and then render it in a template.

<a rel="nofollow" href="{{ url }}">{{ url }}</a>

Upvotes: 0

Rudi
Rudi

Reputation: 19940

I would save the URL itself, and append the tag and parameters at the output. In my opinion it is better to separate the storage, processing and presentation of the data, to accommodate future changes easier (for example when in a future version the URL get used for something entirely other like automated downloads).

Upvotes: 0

Related Questions