Jump to content
  • Advertisement
Sign in to follow this  
InsaneBoarder234

[web] Javascript - Add HTML tags around selection

This topic is 4501 days old which is more than the 365 day threshold we allow for new replies. Please post a new topic.

If you intended to correct an error in the post then please contact us.

Recommended Posts

I'm having difficulty finding suitable pages about this on google. Basically I'm writing a simple editor and I want to add a few buttons that will add tags around the current selection for formatting. So far I have this piece of javascript to apply bold to the selected piece of text.
function ApplyBold()
{
    theSelection = document.selection.createRange().text;
    if(theSelection)
    {
        document.selection.createRange().text = "<strong>" + theSelection + "</strong>";
        document.selection.anchorOffset = selStart;
    }
}

I have a few questions.. (1) How can I only affect the selection if it is within the textarea named 'text' on the form named 'editor'? (2) If there is no selection, or the 'text' textarea doesn't currently have keyboard focus, how can I detect this and use it to simply add "" into the textarea at the location of the cursor? (i.e. if I click at the start of the textarea, then click in another text box, then call ApplyBold() via a button, ApplyBold will insert the strong tag at the start of the 'text' textarea). Thanks!

Share this post


Link to post
Share on other sites
Advertisement
Try this:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<html>
<head>
<title>Untitled</title>

<script type="text/javascript">
function applyTag(obj, tag)
{
wrapText(obj, '<'+tag+'>', '</'+tag+'>');
};

function wrapText(obj, beginTag, endTag)
{
if(typeof obj.selectionStart == 'number')
{
// Mozilla, Opera, and other browsers
var start = obj.selectionStart;
var end = obj.selectionEnd;

obj.value = obj.value.substring(0, start) + beginTag + obj.value.substring(start, end) + endTag + obj.value.substring(end, obj.value.length);
}
else if(document.selection)
{
// Internet Explorer

// make sure it's the textarea's selection
obj.focus();
var range = document.selection.createRange();
if(range.parentElement() != obj) return false;

if(typeof range.text == 'string')
document.selection.createRange().text = beginTag + range.text + endTag;
}
else
obj.value += text;

};
</script>

</head>

<body>

<p>Blah blah blah.</p>

<textarea id="ta" rows="10" cols="50"></textarea> <br /><br />

<input type="button" value="Bold" onclick="applyTag(document.getElementById('ta'), 'b')" />
<input type="button" value="Italics" onclick="applyTag(document.getElementById('ta'), 'i')" />

</body>
</html>

Share this post


Link to post
Share on other sites
Sign in to follow this  

  • Advertisement
×

Important Information

By using GameDev.net, you agree to our community Guidelines, Terms of Use, and Privacy Policy.

We are the game development community.

Whether you are an indie, hobbyist, AAA developer, or just trying to learn, GameDev.net is the place for you to learn, share, and connect with the games industry. Learn more About Us or sign up!

Sign me up!