知道這兩個 DOM 屬性區別的,頭發應該不多了吧?
你可能知道,獲取和設置 DOM 元素內部文本可以用這兩個屬性:Node.textContent 和 Element.innerText。
乍一看,它們似乎做著完全相同的事情,但它們之間有一些微妙但重要的區別。今天,我們來看看它們的作用,以及它們的異同之處。
廢話不說,直接看代碼。
相同之處
比如下面這個 DOM 元素。
- <p id="sandwich">I love a good tuna sandwich!</p>
Node.textContent 和Element.innerText屬性都能獲取#sandwich 元素內部的文本。
- let sandwich = document.querySelector('#sandwich');
- // returns "I love a good tuna sandwich!"
- let text1 = sandwich.textContent;
- // also returns "I love a good tuna sandwich!"
- let text2 = sandwich.innerText;
如果元素內部還有其他標簽,它們都會忽略。
- <p id="sandwich">I love a good <strong>tuna</strong> sandwich!</p>
- // returns "I love a good tuna sandwich!"
- let textHTML1 = sandwich.textContent;
- // also returns "I love a good tuna sandwich!"
- let textHTML2 = sandwich.innerText;
另外,這兩個屬性都能用于設置元素內部文本。
- // 替換文本
- // <p id="sandwich">Hello, world!</p>
- sandwich.textContent = 'Hello, world!';
- // 也可以追加
- // <p id="sandwich">Hello, world! And hi, Universe!</p>
- sandwich.innerText += ' And hi, Universe!';
不同之處
看上去做著同樣的事情,那么它們有什么區別?
- Node.textContent 屬性獲取全部文本內容,包括元素內部那些未渲染到頁面的內容。
- Element.innerText 只返回渲染出來的文本,類似于可以用光標和鍵盤選中的文本部分。
舉個例子就清楚了。
- <div class="greeting">
- <style type="text/css">
- p {
- color: rebeccapurple;
- }
- </style>
- <p hidden>This is not rendered.</p>
- <p>Hello world!</p>
- </div>
- let greeting = document.querySelector('.greeting');
- /* 返回
- p {color: rebeccapurple;}
- This is not rendered.
- Hello world!
- */
- let text1 = greeting.textContent;
- // 返回 "Hello world!"
- let text2 = greeting.innerText;
這下總算知道區別了!又躺學了一個知識點~
本文轉載自微信公眾號「1024譯站」,可以通過以下二維碼關注。轉載本文請聯系1024譯站公眾號。