Please note, this is a STATIC archive of website developer.mozilla.org from November 2016, cach3.com does not collect or store any user information, there is no "phishing" involved.

Edytowanie sformatowanego tekstu (Rich-Text Editing) w Mozilli

To tłumaczenie jest niekompletne. Pomóż przetłumaczyć ten artykuł z języka angielskiego.

Wprowadzenie

Mozilla 1.3 zaimplementowała funkcję designMode firmy Microsoft® z Internet Explorera. Edycja sformatowanego tekstu wspierana w Mozilli 1.3 obsługiwała funkcję designMode, która zamieniała dokumenty HTML w edytory sformatowanego tekstu. Od Firefox 3, Mozilla obsługuje również atrybut Internet Explorera contentEditable, ktory pozwala na edycję dowolnego elementu (editable) lub blokadę edycji (non-editable) - aby zapobiec późniejszym zmianom w środowisku możliwym do edycji.

Ustawienia edycji sformatowanego tekstu

Edytowanie sformatowanego tekstu jest inicjalizowane przez ustawienie własności designMode dokumentu na "On", tak jak dokumentu wewnątrz iframe. Kiedy designMode jest ustawiony na "On", dokument staje się polem edycji sformatowanego tekstu i użytkownik może w nim pisać jak wewnątrz textarea. Większość popularnych skrótów klawiaturowych takich jka kopiuj i wklej jest dostępnych, wszystkie pozostałe muszą zostać zaimplementowane poprzez stronę internetową.

Podobnie, ustawienie contentEditable na "true" pozwala na edycję poszczególnych elementów w dokumencie.

Wykonywanie Komend

Kiedy dokument HTML jest przełączony na designMode, obiekty dokumentu odblokowywują document.execCommand metodę która pozwala na uruchamianie komend aby manipulować zawartością edytowalnego regionu. Większość komend dotyczy zaznaczonej treści (pogrubienie, kursywa, itp.), a inne wstawiają treść (dodawanie linku)  lub operują na całej lini (wcięcie tekstu). Używając contentEditable, wywoływana jest execCommand która operuje na aktualnie edytowalnej zawartości.

Różnice z Internet Explorerem

Jedna z głównych różnic pomiędzy Mozillą a Internet Explorerem polega na tym, że używanie designMode jest generowanym kodem w edytowalnym dokumencie: kiedy Internet Explorer używa znaczników HTML (em, i, itp.), Mozilla 1.3 generuje domyślnie span'y z regułami styli inline. Komenda styleWithCSS aby przełączać pomiędzy formatowaniem CSS i HTML.

Przykład 1 : Różnice w wygenerowanym kodzie HTML

Mozilla:

<span style="font-weight: bold;">Lubię gecko.</span>
<span style="font-weight: bold; font-style: italic; 
    text-decoration: underline;">Dinozaury są duże.</span>

Internet Explorer:

<STRONG>Lubię gecko.</STRONG>
<STRONG><EM><U>Dinozaury są duże.</U></EM></STRONG>

Inną różnicą między Mozillą a IE jest sposób dostępu do obiektu dokumentu wewnątrz iframe, co zazwyczaj działa wraz z designMode. Mozilla używa standardowego sposobu W3C, mianowicie IFrameElement.contentDocument, podczas gdy IE wymaga IFrameElement.document.

DevEdge dostarcza pomocniczą klasę JavaScript, xbDesignMode, która jest wrapper'em dla funkcji designMode dzięki czemu ukrywa różnice pomiędzy IE i Mozillą.


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

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

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

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

<!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 &lt;h1&gt;</option>
<option value="h2">Title 2 &lt;h2&gt;</option>
<option value="h3">Title 3 &lt;h3&gt;</option>
<option value="h4">Title 4 &lt;h4&gt;</option>
<option value="h5">Title 5 &lt;h5&gt;</option>
<option value="h6">Subtitle &lt;h6&gt;</option>
<option value="p">Paragraph &lt;p&gt;</option>
<option value="pre">Preformatted &lt;pre&gt;</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!='https://'){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>
Note: if you want to see how to standardize the creation and the insertion of your editor in your page, please see our more complete rich-text editor example.

Resources

Original Document Information

Autorzy i etykiety dokumentu

 Autorzy tej strony: Zydnar
 Ostatnia aktualizacja: Zydnar,