In my Rails 3 application I use textarea
to let users to write a new message in a forum.
However, when the message is displayed, all newlines look like spaces (there is no <br />
). Maybe there are other mismatch examples, I don't know yet.
I wonder what is the most appropriate way to deal with this.
I guess that the text that is stored in the database is OK (I see for example that <
is converted to <
), so the main problem is the presentation.
Are there build-in helper methods in Rails for this ?
(simple_format does something that looks similar to what I need, but it adds <p>
tags which I don't want to appear.)
Rails got a helper method out of the box, so you dont have to write your own method.
From the documentation:
simple_format(text, html_options={}, options={})
You can use
style="white-space: pre-wrap;"
in the html tag surrounding the text. This respects any line breaks in the text.CSS-only option
I believe one of the easiest options is to use css
white-space: pre-line;
Other answers also mentioned using white-space, but I think it needs a little more information:
In most cases you should probably choose
pre-line
overpre-wrap
. View the difference here.It's very important to keep in mind about
white-space
that you should not do something like this:It will produce extra spaces and line-breaks in the output. Instead, go with this:
HTML alternative
Another way is to wrap your text in
<pre>
tags. And last note on my CSS option is true here as well:Don't separate your text from
<pre>
tags with spaces or line-breaks.Final thoughts
After googling this matter a little I have a feeling that html-approach is considered less clean than the css one and we should go css-way. However, html-way seems to be more browser-compatible (supports archaic browsers, but who cares):
pre tag
white-space
Since
simple_format
does not do what you want, I'd make a simple helper method to convert newlines to<br>
s:Then in your view you can use it like this:
I was using Ace code-editor in my rails app and i had problem, that whenever i update or create the code, it adds always extra TAB on every line (except first). I couldn't solve it with gsub or javascript replace.. But it accidently solved itself when i disabled layout for that template.
So, i solved it with
You'll need to convert the plain text of the textarea to HTML.
At the most basic level you could run a string replacement:
You could also use a special format like Markdown (Ruby library: BlueCloth) or Textile (Ruby library: RedCloth).