https://developer.mozilla.org/en-US/docs/Rich-Text_Editing_in_Mozilla
Introduction
Mozilla 1.3 introduces an implementation of Microsoft® Internet Explorer's designMode feature. The rich-text editing support in Mozilla 1.3 supports the designMode feature which turns HTML documents into rich-text editors. Starting in Firefox 3, Mozilla also supports Internet Explorer's contentEditable
attribute which allows any element to become editable or non-editable (the latter for when preventing change to fixed elements in an editable environment).
Setting Up Rich-Text Editing
Rich-text editing is initialized by setting the designMode
property of a document to "On", such as the document inside an iframe. Once designMode
has been set to "On", the document becomes a rich-text editing area and the user can type into it as if it were a textarea. The most basic keyboard commands such as copy and paste are available, all others need to be implemented by the website.
Similarly, setting contentEditable
to "true" allows you to make individual elements of a document editable.
Executing Commands
When an HTML document has been switched to designMode, the document object exposes the execCommand
method which allows one to run commands to manipulate the contents of the editable region. Most commands affect the document's selection (bold, italics, etc), while others insert new elements (adding a link) or affect an entire line (indenting). When using contentEditable
, calling execCommand
will affect the currently active editable element.
1
|
execCommand(String aCommandName, Boolean aShowDefaultUI, String aValueArgument) |
Arguments
String aCommandName the name of the command Boolean aShowDefaultUI whether the default user interface should be shown. This is not implemented in Mozilla. String aValueArgument some commands (such as insertimage) require an extra value argument (the image's url). Pass an argument of null
if no argument is needed.
Commands
backColor Changes 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. (Internet Explorer uses this to set text background color.) bold Toggles bold on/off for the selection or at the insertion point. (Internet Explorer uses the STRONG tag instead of B.) contentReadOnly Makes the content document either read-only or editable. This requires a boolean true/false to be passed in as a value argument. (Not supported by Internet Explorer.) copy Copies the current selection to the clipboard. Clipboard capability must be enabled in the user.js preference file. See createLink Creates an anchor link from the selection, only if there is a selection. This requires the HREF URI string to be passed in as a value argument. The URI must contain at least a single character, which may be a white space. (Internet Explorer will create a link with a null URI value.) cut Cuts the current selection and copies it to the clipboard. Clipboard capability must be enabled in the user.js preference file. See decreaseFontSize Adds a SMALL tag around the selection or at the insertion point. (Not supported by Internet Explorer.) delete Deletes the current selection. enableInlineTableEditing Enables or disables the table row and column insertion and deletion controls. (Not supported by Internet Explorer.) enableObjectResizing Enables or disables the resize handles on images and other resizable objects. (Not supported by Internet Explorer.) fontName Changes the font name for the selection or at the insertion point. This requires a font name string ("Arial" for example) to be passed in as a value argument. fontSize Changes the font size for the selection or at the insertion point. This requires an HTML font size (1-7) to be passed in as a value argument. foreColor Changes a font color for the selection or at the insertion point. This requires a color value string to be passed in as a value argument. formatBlock Adds an HTML block-style tag 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 to be passed in as a value argument. Virtually all block style tags can be used (eg. "H1", "P", "DL", "BLOCKQUOTE"). (Internet Explorer supports only heading tags H1 - H6, ADDRESS, and PRE, which must also include the tag delimiters < >, such as "<H1>".) forwardDelete Deletes the character ahead of the cursor's position. It is the same as hitting the delete key. heading Adds a heading tag around a selection or insertion point line. Requires the tag-name string to be passed in as a value argument (i.e. "H1", "H6"). (Not supported by Internet Explorer.) hiliteColor Changes the background color for the selection or at the insertion point. Requires a color value string to be passed in as a value argument. UseCSS must be turned on for this to function. (Not supported by Internet Explorer.) increaseFontSize Adds a BIG tag around the selection or at the insertion point. (Not supported by Internet Explorer.) indent Indents 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. insertBrOnReturn Controls whether the Enter key inserts a br tag or splits the current block element into two. (Not supported by Internet Explorer.) insertHorizontalRule Inserts a horizontal rule at the insertion point (deletes selection). insertHTML Inserts an HTML string at the insertion point (deletes selection). Requires a valid HTML string to be passed in as a value argument. (Not supported by Internet Explorer.) insertImage Inserts an image at the insertion point (deletes selection). Requires the image SRC URI string to be passed in as a value argument. The URI must contain at least a single character, which may be a white space. (Internet Explorer will create a link with a null URI value.) insertOrderedList Creates a numbered ordered list for the selection or at the insertion point. insertUnorderedList Creates a bulleted unordered list for the selection or at the insertion point. insertParagraph Inserts a paragraph around the selection or the current line. (Internet Explorer inserts a paragraph at the insertion point and deletes the selection.) insertText Inserts the given plain text at the insertion point (deletes selection). italic Toggles italics on/off for the selection or at the insertion point. (Internet Explorer uses the EM tag instead of I.) justifyCenter Centers the selection or insertion point. justifyFull Justifies the selection or insertion point. justifyLeft Justifies the selection or insertion point to the left. justifyRight Right-justifies the selection or the insertion point. outdent Outdents the line containing the selection or insertion point. paste Pastes the clipboard contents at the insertion point (replaces current selection). Clipboard capability must be enabled in the user.js preference file. See redo Redoes the previous undo command. removeFormat Removes all formatting from the current selection. selectAll Selects all of the content of the editable region. strikeThrough Toggles strikethrough on/off for the selection or at the insertion point. subscript Toggles subscript on/off for the selection or at the insertion point. superscript Toggles superscript on/off for the selection or at the insertion point. underline Toggles underline on/off for the selection or at the insertion point. undo Undoes the last executed command. unlink Removes the anchor tag from a selected anchor link. useCSS Deprecated Toggles 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). (Not supported by Internet Explorer.) This has been deprecated; use the styleWithCSS command instead. styleWithCSS Replaces the useCSS command; argument works as expected, i.e. true modifies/generates style attributes in markup, false generates formatting elements.
Internet Explorer Differences
One major difference between Mozilla and Internet Explorer that affects designMode is the generated code in the editable document: while Internet Explorer uses HTML tags (em, i, etc), Mozilla 1.3 will generate by default spans with inline style rules. The useCSS
command can be used to toggle between CSS and HTML markup creation.
Figure 1 : Generated HTML differences
Mozilla:
1
2
3
|
< span style = "font-weight: bold;" >I love geckos.</ span >
< span style="font-weight: bold; font-style: italic;
text-decoration: underline;">Dinosaurs are big.</ span >
|
Internet Explorer:
1
2
|
< STRONG >I love geckos.</ STRONG >
< STRONG >< EM >< U >Dinosaurs are big.</ U ></ EM ></ STRONG >
|
Another difference between Mozilla and IE is how to access the document object of an iframe, which is usually used in conjunction with designMode. Mozilla uses the W3C standard way, namely IFrameElement.contentDocument
, while IE requires IFrameElement.document
.
DevEdge provides a JavaScript helper class, xbDesignMode
, which is a wrapper for the designMode feature which hides the differences between IE and Mozilla.
Event Handling Disabled
A further difference for Mozilla is that once a document is switched to designMode, all events on that particular document are disabled. Once designMode is turned off however (as this now seems possible in Mozilla 1.5) the events become active again.
More information can be found in the Rich text editing section of Migrate apps from Internet Explorer to Mozilla.
Examples
Please note: The example files are still being migrated from another site. They are not available at this time. --fumble 18:13, 24 Apr 2005 (PDT)
Example 1
The first example is an HTML document setting its own designMode
to "On". This makes the entire document editable in Mozilla 1.3. Internet Explorer, however, does not allow javascript to change the current document's designMode. For it to work in Internet Explorer, the contentEditable
attribute of the body tag needs to be set to "true".
Figure 2 : First example
1
2
3
4
5
6
7
|
HTML: <body contentEditable= "true" onload= "load()" >
JavaScript: function load(){
window.document.designMode = "On" ;
} |
Example 2
The second example is a simple rich text editing page, where text can be bolded/italicized/underlined, new links can be added and the color of text changed. The example page consists of an iframe, which will be the rich editing area, as well as elements for basic editing commands such as bold/italics/text color.
Figure 3 : Setting up rich-text editing
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
HTML: <body onload= "load()" >
JavaScript: function load(){
getIFrameDocument( "editorWindow" ).designMode = "On" ;
} function getIFrameDocument(aID){
// if contentDocument exists, W3C compliant (Mozilla)
if (document.getElementById(aID).contentDocument){
return document.getElementById(aID).contentDocument;
} else {
// IE
return document.frames[aID].document;
}
} |
The example contains a doRichEditCommand
function that makes it easier to execute commands on the iframe's document and keeps the HTML code clean. The function executed the requested command using execCommand()
and then sets focus back to the editable document, as clicking on a button will set focus on the button itself, which breaks the editing flow.
Figure 4 : Executing Rich Editing Commands
1
2
3
4
5
6
7
8
|
HTML: <button onclick= "doRichEditCommand('bold')" style= "font-weight:bold;" >B</button>
JavaScript: function doRichEditCommand(aName, aArg){
getIFrameDocument( 'editorWindow' ).execCommand(aName, false , aArg);
document.getElementById( 'editorWindow' ).contentWindow.focus()
} |
Example: a simple but complete Rich Text Editor
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
|
<!doctype html> < html >
< head >
< title >Rich Text Editor</ title >
< script type = "text/javascript" >
var oDoc, sDefTxt; function initDoc() { oDoc = document.getElementById("textBox");
sDefTxt = oDoc.innerHTML;
if (document.compForm.switchMode.checked) { setDocMode(true); }
} function formatDoc(sCmd, sValue) { if (validateMode()) { document.execCommand(sCmd, false, sValue); oDoc.focus(); }
} function validateMode() { if (!document.compForm.switchMode.checked) { return true ; }
alert("Uncheck \"Show HTML\".");
oDoc.focus();
return false;
} function setDocMode(bToSource) { var oContent;
if (bToSource) {
oContent = document.createTextNode(oDoc.innerHTML);
oDoc.innerHTML = "";
var oPre = document.createElement("pre");
oDoc.contentEditable = false;
oPre.id = "sourceText";
oPre.contentEditable = true;
oPre.appendChild(oContent);
oDoc.appendChild(oPre);
} else {
if (document.all) {
oDoc.innerHTML = oDoc.innerText;
} else {
oContent = document.createRange();
oContent.selectNodeContents(oDoc.firstChild);
oDoc.innerHTML = oContent.toString();
}
oDoc.contentEditable = true;
}
oDoc.focus();
} function printDoc() { if (!validateMode()) { return; }
var oPrntWin = window.open("","_blank","width=450,height=470,left=400,top=100,menubar=yes,toolbar=no,location=no,scrollbars=yes");
oPrntWin.document.open();
oPrntWin.document.write("<!doctype html>< html >< head >< title >Print<\/title><\/head>< body onload=\"print();\">" + oDoc.innerHTML + "<\/body><\/html>");
oPrntWin.document.close();
} </ script >
< style type = "text/css" >
.intLink { cursor: pointer; } img.intLink { border: 0; } #toolBar1 select { font-size:10px; } #textBox { width: 540px;
height: 200px;
border: 1px #000000 solid;
padding: 12px;
overflow: scroll;
} #textBox #sourceText { padding: 0;
margin: 0;
min-width: 498px;
min-height: 200px;
} #editMode label { cursor: pointer; } </ style >
</ head >
< body onload = "initDoc();" >
< form name = "compForm" method = "post" action = "sample.php" onsubmit = "if(validateMode()){this.myDoc.value=oDoc.innerHTML;return true;}return false;" >
< input type = "hidden" name = "myDoc" >
< div id = "toolBar1" >
< select onchange = "formatDoc('formatblock',this[this.selectedIndex].value);this.selectedIndex=0;" >
< option selected>- formatting -</ option >
< option value = "h1" >Title 1 <h1></ option >
< option value = "h2" >Title 2 <h2></ option >
< option value = "h3" >Title 3 <h3></ option >
< option value = "h4" >Title 4 <h4></ option >
< option value = "h5" >Title 5 <h5></ option >
< option value = "h6" >Subtitle <h6></ option >
< option value = "p" >Paragraph <p></ option >
< option value = "pre" >Preformatted <pre></ option >
</ select >
< select onchange = "formatDoc('fontname',this[this.selectedIndex].value);this.selectedIndex=0;" >
< option class = "heading" selected>- font -</ option >
< option >Arial</ option >
< option >Arial Black</ option >
< option >Courier New</ option >
< option >Times New Roman</ option >
</ select >
< select onchange = "formatDoc('fontsize',this[this.selectedIndex].value);this.selectedIndex=0;" >
< option class = "heading" selected>- size -</ option >
< option value = "1" >Very small</ option >
< option value = "2" >A bit small</ option >
< option value = "3" >Normal</ option >
< option value = "4" >Medium-large</ option >
< option value = "5" >Big</ option >
< option value = "6" >Very big</ option >
< option value = "7" >Maximum</ option >
</ select >
< select onchange = "formatDoc('forecolor',this[this.selectedIndex].value);this.selectedIndex=0;" >
< option class = "heading" selected>- color -</ option >
< option value = "red" >Red</ option >
< option value = "blue" >Blue</ option >
< option value = "green" >Green</ option >
< option value = "black" >Black</ option >
</ select >
< select onchange = "formatDoc('backcolor',this[this.selectedIndex].value);this.selectedIndex=0;" >
< option class = "heading" selected>- background -</ option >
< option value = "red" >Red</ option >
< option value = "green" >Green</ option >
< option value = "black" >Black</ option >
</ select >
</ div >
< div id = "toolBar2" >
< img class = "intLink" title = "Clean" onclick = "if(validateMode()&&confirm('Are you sure?')){oDoc.innerHTML=sDefTxt};" src = "" />
< img class = "intLink" title = "Print" onclick = "printDoc();" src = "" >
< img class = "intLink" title = "Undo" onclick = "formatDoc('undo');" src = "" />
< img class = "intLink" title = "Redo" onclick = "formatDoc('redo');" src = "" />
< img class = "intLink" title = "Remove formatting" onclick = "formatDoc('removeFormat')" src = "" >
< img class = "intLink" title = "Bold" onclick = "formatDoc('bold');" src = "" />
< img class = "intLink" title = "Italic" onclick = "formatDoc('italic');" src = "" />
< img class = "intLink" title = "Underline" onclick = "formatDoc('underline');" src = "" />
< img class = "intLink" title = "Left align" onclick = "formatDoc('justifyleft');" src = "" />
< img class = "intLink" title = "Center align" onclick = "formatDoc('justifycenter');" src = "" />
< img class = "intLink" title = "Right align" onclick = "formatDoc('justifyright');" src = "" />
< img class = "intLink" title = "Numbered list" onclick = "formatDoc('insertorderedlist');" src = "" />
< img class = "intLink" title = "Dotted list" onclick = "formatDoc('insertunorderedlist');" src = "" />
< img class = "intLink" title = "Quote" onclick = "formatDoc('formatblock','blockquote');" src = "" />
< img class = "intLink" title = "Add indentation" onclick = "formatDoc('outdent');" src = "" />
< img class = "intLink" title = "Delete indentation" onclick = "formatDoc('indent');" src = "" />
< img class = "intLink" title = "Hyperlink" onclick = "var sLnk=prompt('Write the URL here','http:\/\/');if(sLnk&&sLnk!=''&&sLnk!='http://'){formatDoc('createlink',sLnk)}" src = "" />
< img class = "intLink" title = "Cut" onclick = "formatDoc('cut');" src = "" />
< img class = "intLink" title = "Copy" onclick = "formatDoc('copy');" src = "" />
< img class = "intLink" title = "Paste" onclick = "formatDoc('paste');" src = "" />
</ div >
< div id = "textBox" contenteditable = "true" >< p >Lorem ipsum</ p ></ div >
< p id = "editMode" >< input type = "checkbox" name = "switchMode" id = "switchBox" onchange = "setDocMode(this.checked);" /> < label for = "switchBox" >Show HTML</ label ></ p >
< p >< input type = "submit" value = "Send" /></ p >
</ form >
</ body >
</ html >
|
Resources
- mozilla.org's rich-text editing Specification
- mozilla.org's rich-text editing Demo
- Converting an app using document.designMode from IE to Mozilla at mozilla.org
- MSDN: designMode Property
- MSDN: How to Create an HTML Editor Application
- A closed source, cross-browser rich-text editing demo
- xbDesignMode; a JavaScript helper class for easier cross-browser development using designMode.
- Firefox 3 and contentEditable
Original Document Information
- Author(s): Doron Rosenberg, Netscape Communications
- Published: 04 Apr 2003
- Revised: 01 Jul 2003
- Revised: 24 Apr 2005, Joel Coreson
- Revised: 28 Nov 2006, Ken Kuhns, ComputronicsUSA
- Revised: 19 Dec 2007, Mark Finkle
相关推荐
ViEmu/VS: vi-vim editing for Microsoft Visual Studio ViEmu for Visual Studio is the most popular and mature product of the ViEmu line. Many hundreds of developers use it all day, every day for all ...
In a surprisingly short period of time, Visual Studio Code has become very popular among web developers. Part of that is because it’s fast, lightweight, and is available on the three main platforms ...
论文 Deep White-Balance Editing 的参考代码。 Mahmoud Afifi 和 Michael S. Brown,CVPR 2020。 ** 先决条件 ** 1. Matlab 2019b 或更高版本2. 深度学习工具箱3. 图像处理工具箱 ** 开始 ** 1. 运行 install_.m ...
根据给出的文件信息,文件标题为“the craft of text editing”,描述是“the craft of text editing 一本电子书。放在这里收藏。”标签也是“the craft of text editing”,而【部分内容】中呈现的内容由于OCR技术...
bash-vi-editing-mode-cheat-sheet Readline VI Editing Mode Cheat Sheet Default Keyboard Shortcuts for Bash
The video-editing-timeline repo contains three packages: video-editing-timeline (native version), video-editing-timeline-react (react version), and video-editing-timelinevue (vue version). You can ...
《geomajas-plugin-editing-javascript-api-1.15.0-M3.zip》是一个与开源GIS(地理信息系统)相关的压缩包,主要包含了用于GWT(Google Web Toolkit)客户端的编辑功能的JavaScript API。这个API是geomajas项目的一...
标题中的"success-128-switch-editing.zip_editing"暗示了这是一个关于编辑与修改的项目,可能涉及数字电路设计,特别是与128个开关有关的系统。描述提到"controlling D flipflop circuit",这直接指向了数字电子...
React Native Drag Text编辑器 React Native Draggable&Editable&Resizable Text Component,仍在早期开发中,用于照片编辑/处理案例。 :star:如果这个项目对您有帮助,请加星号支持。 展示柜[IOS13 / AndroidAPI...
"写作助手软件Text Editing Assistant 9.4 绿色版_" 是一款专为提升写作效率而设计的应用程序,它提供了一系列实用工具,旨在帮助用户在创作过程中更加便捷地完成各种任务。这款软件不仅包含了丰富的符号和ASCII、...
目录RNA-editing分析实战- 获取合适的测试数据RNA-editing分析实战获取合适的测试数据 目录我们要找到的数据集要满足以下几个条件:- ribo
在IT领域,存在多种文本编辑器,包括Vim、Emacs、Sublime Text、Atom、Visual Studio Code等。每种编辑器都有其独特的优势和适用场景,例如Vim以其高效的键盘操作而著称,适用于快速代码编辑;而Visual Studio Code...
The Closure Library is a broad, well-tested, modular, and cross-browser JavaScript library. You can pull just what you need from a large set of reusable UI widgets and ... rich-text editing, and more
此外,Sublime Text的Split Editing特性允许用户同时编辑同一文件的不同部分,或者同时编辑两个不同的文件,对于对比代码或并行工作非常有帮助。 用户界面方面,Sublime Text以其简洁、清晰的设计赢得了好评。...
为输入字段和可编辑的文本内容添加搜索和替换工具。 查找和替换文本编辑是一个扩展,使您可以直接在浏览器中搜索和替换输入区域中的文本。 它包括搜索历史记录,收藏夹,模板,突出显示和高级正则表达式模式。...
**正文** 《高效能人士的七个文本编辑习惯》是一本专为程序员设计的指南,它深入探讨了如何利用 Vim 编辑器提升编程效率。Vim 是一款强大的文本编辑器,以其高度可定制化和高效的键盘操作而备受程序员喜爱。...
在线照片编辑器-免费在线编辑图像 在线照片编辑器使您可以编辑照片,应用效果,滤镜,添加文本,裁剪或调整图片大小。 在浏览器中免费进行在线照片编辑! 此扩展程序可以在线进行高级的免费照片编辑,还可以使用专业...
此外,JSF提供了一套**组件(Components)**,如`h:inputText`用于文本输入,`h:commandButton`用于提交表单,以及`h:dataTable`用于展示数据。在描述的示例中,`h:dataTable`可能被用来显示用户列表,并且可能结合`...
在Linux系统中,Bash是默认的命令行界面,而Vim是一个功能强大的文本编辑器,两者通常在系统管理和软件开发中扮演重要角色。此文档是一份关于在Bash中使用Vim模式编辑命令行的快捷参考,即通过在用户主目录下的....
要查看的文件: (VB: )如何调用约会编辑表而不是就地编辑下面的示例演示如何更改最终用户在Scheduler控件中按下键时执行的默认操作。 默认情况下将调用就地编辑器,从而使用户能够修改“主题”字段。...