Get to know MDN better
Deprecated: This feature is no longer recommended. Though some browsers might still support it, it may have already been removed from the relevant web standards, may be in the process of being dropped, or may only be kept for compatibility purposes. Avoid using it, and update existing code if possible; see the compatibility table at the bottom of this page to guide your decision. Be aware that this feature may cease to work at any time.
Non-standard: This feature is not standardized. We do not recommend using non-standard features in production, as they have limited browser support, and may change or be removed. However, they can be a suitable alternative in specific cases where no standard option exists.
Note: Although the execCommand() method is deprecated, there are still some valid use cases that do not yet have viable alternatives. For example, unlike direct DOM manipulation, modifications performed by execCommand() preserve the undo buffer (edit history). For these use cases, you can still use this method, but test to ensure cross-browser compatibility, such as by using document.queryCommandSupported().
The execCommand method implements multiple different commands. Some of them provide access to the clipboard, while others are for editing form inputs, contenteditable elements or entire documents (when switched to design mode).
To access the clipboard, the newer Clipboard API is recommended over execCommand().
Most commands affect the document's selection. For example, some commands (bold, italics, etc.) format the currently selected text, while others delete the selection, insert new elements (replacing the selection) or affect an entire line (indenting). Only the currently active editable element can be modified, but some commands (e.g., copy) can work without an editable element.
Note: Modifications performed by execCommand() may or may not trigger beforeinput and input events, depending on the browser and configuration. If triggered, the handlers for the events will run before execCommand() returns. Authors need to be careful about such recursive calls, especially if they call execCommand() in response to these events. From Firefox 82, nested execCommand() calls will always fail, see bug 1634262.
A string specifying the name of the command to execute. The following commands are specified:
backColorChanges the document background color. In styleWithCss mode, it affects the background color of the containing block instead. This requires a <color> value string to be passed in as a value argument.
boldToggles bold on/off for the selection or at the insertion point.
contentReadOnlyMakes the content document either read-only or editable. This requires a boolean true/false as the value argument.
copyCopies the current selection to the clipboard. Conditions of having this behavior enabled vary from one browser to another, and have evolved over time. Check the compatibility table to determine if you can use it in your case.
createLinkCreates a hyperlink from the selection, but only if there is a selection. Requires a URI string as a value argument for the hyperlink's href. The URI must contain at least a single character, which may be whitespace.
cutRemoves the current selection and copies it to the clipboard. When this behavior is enabled varies between browsers, and its conditions have evolved over time. Check the compatibility table for usage details.
decreaseFontSizeAdds a <small> tag around the selection or at the insertion point.
defaultParagraphSeparatorChanges the paragraph separator used when new paragraphs are created in editable text regions.
deleteDeletes the current selection.
enableAbsolutePositionEditorEnables or disables the grabber that allows absolutely-positioned elements to be moved around. The grabber is disabled by default since Firefox 64 (Firefox bug 1490641).
enableInlineTableEditingEnables or disables the table row/column insertion and deletion controls. The controls are disabled by default since Firefox 64 (Firefox bug 1490641).
enableObjectResizingEnables or disables the resize handles on images, tables, and absolutely-positioned elements and other resizable objects. The handles are disabled by default since Firefox 64 (Firefox bug 1490641).
fontNameChanges the font name for the selection or at the insertion point. This requires a font name string (like "Arial") as a value argument.
fontSizeChanges the font size for the selection or at the insertion point. This requires an integer from 1 - 7 as a value argument.
foreColorChanges a font color for the selection or at the insertion point. This requires a hexadecimal color value string as a value argument.
formatBlockAdds an HTML block-level element around the line containing the current selection, replacing the block element containing the line if one exists (in Firefox, <blockquote> is the exception — it will wrap any containing block element). Requires a tag-name string as a value argument. Virtually all block-level elements can be used. (Legacy Edge only supports heading tags H1 – H6, ADDRESS, and PRE, which must be wrapped in angle brackets, such as "<H1>".)
forwardDeleteDeletes the character ahead of the cursor's position, identical to hitting the Delete key on a Windows keyboard.
headingAdds a heading element around a selection or insertion point line. Requires the tag-name string as a value argument (i.e., "H1", "H6"). (Not supported by Safari.)
hiliteColorChanges the background color for the selection or at the insertion point. Requires a color value string as a value argument. useCSS must be true for this to function.
increaseFontSizeAdds a <big> tag around the selection or at the insertion point.
indentIndents the line containing the selection or insertion point. In Firefox, if the selection spans multiple lines at different levels of indentation, only the least indented lines in the selection will be indented.
insertBrOnReturnControls whether the Enter key inserts a <br> element, or splits the current block element into two.
insertHorizontalRuleInserts a <hr> element at the insertion point, or replaces the selection with it.
insertHTMLInserts an TrustedHTML instance or string of HTML markup at the insertion point (deletes selection). This requires valid HTML markup.
Warning: The input is parsed as HTML and written into the DOM. APIs like this are known as injection sinks, and are potentially a vector for cross-site scripting (XSS) attacks, if the input originally came from an attacker.
You can mitigate this risk by always assigning TrustedHTML objects instead of strings and enforcing trusted types. See the Trusted Types API for more information.
Inserts an image at the insertion point (deletes selection). Requires a URL string for the image's src as a value argument. The requirements for this string are the same as createLink.
insertLineBreakDeletes the selection, and replaces it with a line break element.
insertOrderedListCreates a numbered ordered list for the selection or at the insertion point.
insertUnorderedListCreates a bulleted unordered list for the selection or at the insertion point.
insertParagraphInserts a paragraph around the selection or the current line.
insertTextInserts the given plain text at the insertion point (deletes selection).
italicToggles italics on/off for the selection or at the insertion point.
justifyCenterCenters the selection or insertion point.
justifyFullJustifies the selection or insertion point.
justifyLeftJustifies the selection or insertion point to the left.
justifyRightRight-justifies the selection or the insertion point.
outdentOutdents the line containing the selection or insertion point.
pastePastes the clipboard contents at the insertion point (replaces current selection).
This feature is specified as disabled for web content, but has been implemented via the Clipboard API on some browsers. On these browsers the feature requires transient activation, and acknowledgement of a popup UI when pasting cross-origin content. See the Browser compatibility table for more information.
redoRedoes the previous undo command.
removeFormatRemoves all formatting from the current selection.
selectAllSelects all of the content of the editable region.
strikeThroughToggles strikethrough on/off for the selection or at the insertion point.
subscriptToggles subscript on/off for the selection or at the insertion point.
superscriptToggles superscript on/off for the selection or at the insertion point.
underlineToggles underline on/off for the selection or at the insertion point.
undoUndoes the last executed command.
unlinkRemoves the anchor element from a selected hyperlink.
useCSSToggles the use of HTML tags or CSS for the generated markup. Requires a boolean true/false as a value argument.
Note: This argument is logically backwards (i.e., use false to use CSS, true to use HTML). This has been deprecated in favor of styleWithCSS.
Replaces the useCSS command. true modifies/generates style attributes in markup, false generates presentational elements.
AutoUrlDetectChanges the browser auto-link behavior.
showDefaultUIA boolean value indicating whether the default user interface should be shown. This is not implemented in Mozilla.
valueArgumentFor commands which require an input argument, is a string providing that information. For example, insertImage requires the URL of the image to insert. Specify null if no argument is needed.
A boolean value that is false if the command is unsupported or disabled.
Note: document.execCommand() only returns true if it is invoked as part of a user interaction. You can't use it to verify browser support before calling a command.
This example shows two very basic HTML editors, one using a <textarea> element and one using a <pre> element with the contenteditable attribute set.
Clicking the "Bold" or "Italic" buttons inserts the appropriate tags in the element, using insertText to preserve the edit history, so the user can undo the action.
This example has a <textarea> element, and a <button> element that you can use to paste content into it.
On browsers that implement this feature using the Clipboard API you should be able to copy same-origin content, such as text from the text area, and then paste it to replace any selected content. When you try to paste cross-origin content, such as text copied from any other page or location, you will first need to select the "Paste" UI that is displayed.
This feature is not part of any current specification. It is no longer on track to become a standard. There is an unofficial W3C execCommand spec draft.
Enable JavaScript to view this browser compatibility table.
This page was last modified on May 9, 2026 by MDN contributors.
Your blueprint for a better internet.
Visit Mozilla Corporation’s not-for-profit parent, the Mozilla Foundation.
Portions of this content are ©1998–2026 by individual mozilla.org contributors. Content available under a Creative Commons license.