Solved

Javascript (or CSS) textarea word wrap Firefox

Posted on 2009-07-16
3
1,075 Views
Last Modified: 2012-08-13
I couldn't find a clear solution on this, but it seems like it would have a quick, easy answer by now.  I have a textarea field for notes.  It looks like this:

<textarea name=inspnotes cols=21 rows=13></textarea>

In firefox, the warp property is not recognized, so I need an alternative method of wrapping a user's text when they reach 21 columns.  
I found the attached javascript, and it works fine for the first line of text, but I do not understand the part of the script that uses the modulus operator, so the subsequent lines of text do not wrap properly. If there is a better way to do this other than javascript(maybe CSS), please let me know.  Thanks for reading.
<script language="javascript" type="text/javascript">
var ijk = 0;
function txt_ara()
{
//alert("1");
//alert(document.getElementById("email").value.length);
//var ijk = 0;
//var incr = 2;
if(document.getElementById("email").value.length <= 21)
{
if(document.getElementById("email").value.length == 21)
{
document.getElementById("email").value += "\n";
}
}
else
{
var lkm = "";
if(ijk == 0)
{
lkm = parseInt(document.getElementById("email").value.length % 120);  //This is what I don't understand.  What value should I set this to?
}
else
{
lkm = parseInt(document.getElementById("email").value.length % 60);  //This is what I don't understand.  What value should I set this to?
}
if(lkm == 0)
{
ijk = 1;
document.getElementById("email").value += "\n";
}
}
}
</script> 
 
<textarea name=inspnotes cols=21 rows=13 id=email onkeyup="txt_ara();" onkeydown="txt_ara();"></textarea>

Open in new window

0
Comment
Question by:thedeal56
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
3 Comments
 
LVL 11

Accepted Solution

by:
level9wizard earned 500 total points
ID: 24868983
Why not do something like this:

<!-- HTML -->
<textarea class="email"></textarea>

/* CSS */
.email
{
    display: block;
    width: 200px; /* set this to whatever you need */
}
0
 

Author Comment

by:thedeal56
ID: 24869046
Thanks for the fast reply.  BTW, your name is awesome.

Here's what I did:

.email
{
    display: block;
    width: 200px;
}

<textarea name=inspnotes cols=21 rows=13 class=email></textarea>


Still no word wrap.  
0
 

Author Comment

by:thedeal56
ID: 24898577
I started thinking about this question, and I realized that I might not have been specific enough about my problem.  The error that I'm having is when a user is inputting text the words do not wrap to the box's width.  I thought I might should clear that up, because it might have sounded like I was having trouble displaying the text rather than trouble entering it in.  
0

Featured Post

Salesforce Made Easy to Use

On-screen guidance at the moment of need enables you & your employees to focus on the core, you can now boost your adoption rates swiftly and simply with one easy tool.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Building a website can seem like a daunting task to the uninitiated but it really only requires knowledge of two basic languages: HTML and CSS.
Boost your ability to deliver ambitious and competitive web apps by choosing the right JavaScript framework to best suit your project’s needs.
In this tutorial viewers will learn how to style a corner ribbon overlay for an image using CSS Create a new class by typing ".Ribbon":  Define the class' "display:" as "inline-block": Define its "position:" as "relative": Define its "overflow:" as …
The viewer will learn the benefit of using external CSS files and the relationship between class and ID selectors. Create your external css file by saving it as style.css then set up your style tags: (CODE) Reference the nav tag and set your prop…
Suggested Courses

623 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question