Różnica między tekstem wewnętrznym a tekstem wewnętrznym HTML

256

Jaka jest różnica między JavaScript innerHTML, innerTexta childNodes[].valueJavaScript?

użytkownik 2819851
źródło
4
@tymeJV Szczerze mówiąc, rozróżnienie innerTextna niestandardową implementację textContext przez MSIE nie jest trywialne.
fny
4
Poza tym, że funkcja wewnętrznaTekst nie działa w przeglądarce Firefox: textContent wydaje się działać we wszystkich głównych przeglądarkach, więc po prostu użyj textContent zamiast innerText.
auco
5
WAŻNA UWAGA: powyższe 3 komentarze nie są już ważne. innerTextzostał dodany do standardów i obsługiwany przez wszystkie główne przeglądarki. textContentjest teraz obsługiwany przez IE> = 9 i może być używany zamiast innerTextw większości przypadków (bonus, jest znacznie szybszy), ale są między nimi różnice, więc w niektórych przypadkach nie można ich zamienić.
Racil Hilan
3
Aktualizacja 2019: innerTextjest dobrze obsługiwana we wszystkich przeglądarkach. Firefox zaczął obsługiwać go od wersji 45. caniuse.com/#search=innertext
Aditya Gupta
Dziwi mnie, że nie ma tu mowy o bezpieczeństwie. innerHTML jest znaną podatnością na ataki XSS. To powiedziawszy, innerTextnie jest również w 100% bezpieczne. stackoverflow.com/questions/52707031/does-innertext-prevent-xss blog.cloudboost.io/…
davidhartman00

Odpowiedzi:

147

W przeciwieństwie do innerTexttego innerHTMLpozwala pracować z tekstem sformatowanym HTML i nie koduje i nie dekoduje automatycznie. Innymi słowy, innerTextpobiera i ustawia zawartość znacznika jako zwykły tekst, podczas gdy innerHTMLpobiera i ustawia treść w formacie HTML.

alejo802
źródło
7
Bardzo ważne jest, aby wkleić tutaj w zaakceptowanej odpowiedzi @ komentarz jora poniżej w innej odpowiedzi: „Tylko dla jasności: dotyczy to tylko USTAWIANIA wartości. Podczas uzyskiwania wartości znaczniki HTML są po prostu usuwane i pojawia się zwykły tekst”.
Heitor,
261

Poniższe przykłady odnoszą się do następującego fragmentu kodu HTML:

<div id="test">
   Warning: This element contains <code>code</code> and <strong>strong language</strong>.
</div>

Do węzła będzie odwoływał się następujący JavaScript:

var x = document.getElementById('test');


element.innerHTML

Ustawia lub pobiera składnię HTML opisującą potomków elementu

x.innerHTML
// => "
// =>   Warning: This element contains <code>code</code> and <strong>strong language</strong>.
// => "

Jest to część specyfikacji parsowania i serializacji DOM W3C . Uwaga: jest to właściwość Elementobiektów.


node.innerText

Ustawia lub pobiera tekst między znacznikami początkowym i końcowym obiektu

x.innerText
// => "Warning: This element contains code and strong language."
  • innerTextzostał wprowadzony przez Microsoft i przez pewien czas nie był obsługiwany przez Firefox. W sierpniu 2016 r. innerTextZostał przyjęty przez WHATWG i został dodany do przeglądarki Firefox w wersji 45.
  • innerText zapewnia stylową reprezentację tekstu, który próbuje dopasować do tego, co renderuje przeglądarka, co oznacza:
    • innerTextobowiązuje text-transformi white-spacereguluje
    • innerText przycina białe spacje między liniami i dodaje podział linii między elementami
    • innerText nie zwróci tekstu dla niewidocznych elementów
  • innerTextpowróci textContentdla elementów, które nigdy nie są renderowane jak <style />i `
  • Właściwość Nodeelementów


node.textContent

Pobiera lub ustawia zawartość tekstową węzła i jego potomków.

x.textContent
// => "
// =>   Warning: This element contains code and strong language.
// => "

Chociaż jest to standard W3C , nie jest obsługiwany przez IE <9.

  • Nie jest świadomy stylu i dlatego zwróci treści ukryte przez CSS
  • Nie wyzwala ponownego wlania (dlatego jest bardziej wydajny)
  • Właściwość Nodeelementów


node.value

Ten zależy od elementu, na który celujesz. W powyższym przykładzie xzwraca obiekt HTMLDivElement , który nie ma valuezdefiniowanej właściwości.

x.value // => null

<input />Na przykład tagi wejściowe ( ) definiują valuewłaściwość , która odnosi się do „bieżącej wartości w kontrolce”.

<input id="example-input" type="text" value="default" />
<script>
  document.getElementById('example-input').value //=> "default"
  // User changes input to "something"
  document.getElementById('example-input').value //=> "something"
</script>

Z dokumentów :

Uwaga: w przypadku niektórych typów danych wejściowych zwracana wartość może nie być zgodna z wartością wprowadzoną przez użytkownika. Na przykład, jeśli użytkownik wprowadzi wartość nienumeryczną do <input type="number">, zwrócona wartość może być pustym ciągiem.


Przykładowy skrypt

Oto przykład, który pokazuje wynik dla HTML przedstawionego powyżej:

var properties = ['innerHTML', 'innerText', 'textContent', 'value'];

// Writes to textarea#output and console
function log(obj) {
  console.log(obj);
  var currValue = document.getElementById('output').value;
  document.getElementById('output').value = (currValue ? currValue + '\n' : '') + obj; 
}

// Logs property as [propName]value[/propertyName]
function logProperty(obj, property) {
  var value = obj[property];
  log('[' + property + ']'  +  value + '[/' + property + ']');
}

// Main
log('=============== ' + properties.join(' ') + ' ===============');
for (var i = 0; i < properties.length; i++) {
  logProperty(document.getElementById('test'), properties[i]);
}
<div id="test">
  Warning: This element contains <code>code</code> and <strong>strong language</strong>.
</div>
<textarea id="output" rows="12" cols="80" style="font-family: monospace;"></textarea>

pieprzony
źródło
1
Nawet najnowsze wersje Firefoksa nie obsługują innerText: quirksmode.org/dom/html i quirksmode.org/dom/tests/innerhtml.html
Jarno Lamberg
Pomocne byłoby podzielenie każdej z czterech właściwości (innerHTML, innerText, textContent, wartość) na dwa podtytuły: zachowanie „get” i zachowanie „set”.
Luke Hutchison
3
Według autora.mozilla.org/en-US/docs/Web/API/Node/innerText Firefox >=45 jest obsługiwany.
Kilmazing
4
Jeśli dobrze rozumiem MDN , innerTextjest on teraz częścią Standardu i powinien być obsługiwany przez Firefox od wersji 45; być może powód aktualizacji tej świetnej odpowiedzi @faraz
domsson
1
To również konwertuje &lt;do <, &gt;do >, itp
SarcasticSully
23

InnerTextwłaściwość html-koduje zawartość, przechodząc <p>do &lt;p&gt;itp. Jeśli chcesz wstawić tagi HTML, musisz użyć InnerHTML.

guymid
źródło
8
Dla jasności: dotyczy to tylko USTAWIANIA wartości. Podczas uzyskiwania wartości znaczniki HTML są po prostu usuwane i otrzymujesz zwykły tekst.
jor
9

W prostych słowach:

  1. innerTextpokaże wartość taką jaka jest i ignoruje wszelkie HTMLformatowanie, które może być uwzględnione.
  2. innerHTMLpokaże wartość i zastosuje dowolne HTMLformatowanie.
Bałkański
źródło
3
var element = document.getElementById("main");
var values = element.childNodes[1].innerText;
alert('the value is:' + values);

Aby na przykład go udoskonalić i odzyskać wartość Alec, użyj innego .childNodes [1]

var element = document.getElementById("main");
var values = element.childNodes[1].childNodes[1].innerText;
alert('the value is:' + values);
kaushik0033
źródło
2

Pod względem MutationObserversustawienia ustawienie innerHTMLpowoduje childListmutację z powodu usunięcia węzła przez przeglądarki, a następnie dodania nowego węzła o wartości innerHTML.

Jeśli ustawisz innerText, characterDatagenerowana jest mutacja.

Nikos
źródło
2

Jedyną różnicą między innerTexti innerHTMLjest to, że innerTextwstawia ciąg znaków w elemencie, a innerHTMLuruchamia go jako zawartość HTML.

const ourstring = 'My name is <b class="name">Satish chandra Gupta</b>.';
document.getElementById('innertext').innerText = ourstring;
document.getElementById('innerhtml').innerHTML = ourstring;
.name{
color:red;
}
<h3>Inner text below. It inject string as it is into the element.</h3>
<div id="innertext"></div>
<br />
<h3>Inner html below. It renders the string into the element and treat as part of html document.</h3>
<div id="innerhtml"></div>

Satish Chandra Gupta
źródło
1

InnerTextzwróci tylko wartość tekstową strony z każdym elementem w nowym wierszu w postaci zwykłego tekstu, podczas gdy innerHTMLzwróci treść HTML wszystkiego wewnątrz bodyznacznika i childNodeszwróci listę węzłów, jak sugeruje nazwa.

scrblnrd3
źródło
1

innerTextWłaściwość zwraca tekście wartości elementu html natomiast innerHTMLzwraca HTML content. Przykład poniżej:

var element = document.getElementById('hello');
element.innerText = '<strong> hello world </strong>';
console.log('The innerText property will not parse the html tags as html tags but as normal text:\n' + element.innerText);

console.log('The innerHTML element property will encode the html tags found inside the text of the element:\n' + element.innerHTML);
element.innerHTML = '<strong> hello world </strong>';
console.log('The <strong> tag we put above has been parsed using the innerHTML property so the .innerText will not show them \n ' + element.innerText);
console.log(element.innerHTML);
<p id="hello"> Hello world 
</p>

NickAth
źródło
0

aby dodać do listy, innerText zachowa twoją transformację tekstu, innerHTML wont

Teiem
źródło