How to add class or id or CSS style in execCommand formatBlock 'p' tag?
Solution 1
If you want to add id or class for CSS in content editable div, then you will use below code---
<script>
function CssFnctn()
{
document.execCommand('formatblock', false, 'p')
var listId = window.getSelection().focusNode.parentNode;
$(listId).addClass("oder2");
}
</script>
.oder2
{
padding-left: 3em;
}
Solution 2
There are many ways to do it. Just use execCommand 'insertHTML' instead to replace selected text with wrapped code. Like this:
selection = window.getSelection().toString();
wrappedselection = '<span class="accent" style="somestyle">' + selection + '</span>';
document.execCommand('insertHTML', false, wrappedselection);
This will remove breaklines, tags like <b>
, <i>
and other intext-html-formatting - to keep them you need smth like this (thx to post):
selection = window.getSelection().getRangeAt(0).cloneContents();
span = document.createElement('span');
span.appendChild(selection);
wrappedselection = '<span class="accent1">'+span.innerHTML+'</span>';
document.execCommand('insertHTML', false, wrappedselection);
This insertHTML does not works with IE. Check Documentation https://developer.mozilla.org/en-US/docs/Web/API/Document/execCommand
Solution 3
I got the solution.
Javascript:
function line(){
window.execCommand('formatblock', false, 'p');
selectedElement = window.getSelection().focusNode.parentNode;
selectedElement.style.marginBottom = '100px';
}
HTML
<input type="button" value="addMarginBottom" onclick="javascript:line();"/>
<div class="textcontent" contenteditable ="true"></div>
This is work perfectly for me. But i can not make jsfiddle right now. This is work for one line fine but not multiple line.
Solution 4
To add the class to the p tag, I think it should actually be like this...
function CssFnctn() {
document.execCommand('formatblock', false, 'p')
var listId = window.getSelection().anchorNode.parentNode;
listId.classList = 'oder2';
}
Notice the anchorNode instead of focusNode
Solution 5
Try this code: http://jsfiddle.net/lotusgodkk/GCu2D/57/
Javascript:
$(document).ready(function () {
$('div').click(function () {
var sel = window.getSelection();
var range = document.createRange();
el = document.getElementById('one'); //Get the element
range.selectNodeContents(el);
sel.removeAllRanges();
sel.addRange(range);
document.execCommand('formatblock', false, null); //execute command.
document.execCommand('bold', false, null); //execute command.
});
});
HTML
<div contenteditable="true">
<p id="one">Sample text</p>
<p>Sample text 2</p>
</div>
Akhi
I'm new here. So please help to be a good programmer in php jquery and Ajax. Thanks to All.
Updated on July 28, 2022Comments
-
Akhi almost 2 years
I want to use execcommand 'formatblock' for select a line by 'p' tag or span with specific class or Id or any css style in my contenteditable div(own rich text editor). i searched a lot for this, but i could not find anything which valuable for me.
document.execCommand('formatblock', false, 'p');
How can i add class or id or css in this code?
-
Akhi about 10 yearsActually when i put my cursor in a line of the div then i click a button which belongs with execcommand formatblock 'P'. Then the line text will be go in the p tag. My question is--- is it possible to add any class or id or css with this p tag?
-
K K about 10 yearsSo when you add a line text in the p tag then the focus will be set on the p tag, right? If yes, then you can select the focused element by following ways and then add class/style on it: // Get the focused element: var $focused = $(':focus'); // No jQuery: var focused = document.activeElement; // Does the element have focus: var hasFocus = $('foo').is(':focus'); // No jQuery: elem === elem.ownerDocument.activeElement; Correct me if I misunderstood your question.
-
Akhi about 10 yearsWould you please give me any example?
-
K K about 10 yearsYou should create a fiddle for your code which adds a text line in "P" tag. Then it will be easier for me to help you.
-
Tim about 8 yearsNot very reliable. Often you can get adjacent nodes of a text selection instead of the new
p
. -
Ankur Aggarwal over 7 years@Tim yes getting that problem. Any alternative solution?
-
Tim over 7 years@Ankur Aggarwal: I couldn't come up with one. In the end I gave up on contenteditable, instead am using Markdown. Might go back to contenteditable with Web Standards improve.
-
Ahtisham over 5 yearsIt should be
window.getSelection().focusNode
without aparentNode