We help IT Professionals succeed at work.

Check out our new AWS podcast with Certified Expert, Phil Phillips! Listen to "How to Execute a Seamless AWS Migration" on EE or on your favorite podcast platform. Listen Now

x

Storing text from a <form> without loosing linebreaks.

aspdev
aspdev asked
on
Medium Priority
173 Views
Last Modified: 2013-12-25
I need help. I need to be able to store the text from a "textarea" in a table and retrieve it again without loosing the linebreaks made when "return" is pressed during the typing in the field. I am using ASP.
Comment
Watch Question

Commented:
You could use the normal procedure, "returns" are saved into the database as well. The contents of a <TEXTAREA> should be stored into a memo-field (using Access), or a field of the type "text" (using MS SQL).

If you really want to be sure (and avoid trouble with quotes), you could URLEncode the text before storing it (Server.URLEncode) and decode it again before displaying.

Author

Commented:
I store it in a MS SQL "text" field. I even URLEncode it, but the "returns" still ain't there... what is the problem? I add the data by calling it with Request.Form("Info")...

Commented:
The returns are converted to %something when the string is urlencoded, you have to decode it to get them back.

Commented:
Oh and by the way, a return in text, is not a return in HTML, if you want the returns to be converted to HTML, then use a replace function, which replaces the returns with "<p>" or "<br>".

REPLACE(YourString, CHR(10), "<p>")
will replace linefeed
CHR(13) is carriage return, you might want to use that maybe.

Commented:
mayby you shoud place int in a textarea of 0x0 in the table

Commented:
Use the "wrap=virtual" flag:

<textarea wrap=virtual ...>

//madduck

Author

Commented:
That didn't work. No diffrence at all.
I came up with the idea to URLEncode the the data and then replace all "%0D%0A" with "<br>" before I URLDecode it. The problem is that I lose all "spaces" since they are converted into a "+" sign and If I change that to spaces, then I'd lose the "real" +:es.
What I need to do is to (store) and later retrieve the whole text including "returns".

Commented:
Now I get it. A real + would be coded as %20, so you would first convert "+" to " " and then "%20" to "+".

How about using a CGI library? This will do it for you!

Author

Commented:
I solved it on my own. I really aprreciate your help, especially sybe who, I could give some credit for the idea with CHR(13). Had to do some more things though... oh well... thank you all!

Commented:
sybe, then please answer this so that aspdev cxan award you.

later pals!

Commented:
oh yeah, and aspdev, please tell us quickly what you did so that this question is a useful PAQ!

Author

Commented:
Sorry.
I HTMLEncoded it before I stored it in the database.
Then I retrived it and replaced all CHR(13) with "<br>". To enable a person to add more than one "space" in a row, I added that it also changed the " " to "&#160;".


Author

Commented:
And one more thing, it is useful to relace only "  " (notice the TWO spaces) with " &#160;" since you otherwise will have onle long line with what for the browser looks like one word "and&3160;then&#160;I&#160;" ect. That will disable the wordwrapping. So only replace when it is more than one space and replace with one space and one &#160;
Commented:
Unlock this solution and get a sample of our free trial.
(No credit card required)
UNLOCK SOLUTION

Author

Commented:
I guess you could. Want to say thanx to madduck too but you are the one who gave me part of the idea to the solution. Thanx! here you are.
Unlock the solution to this question.
Thanks for using Experts Exchange.

Please provide your email to receive a sample view!

*This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.

OR

Please enter a first name

Please enter a last name

8+ characters (letters, numbers, and a symbol)

By clicking, you agree to the Terms of Use and Privacy Policy.