您好,登錄后才能下訂單哦!
本篇內容介紹了“兩個DOM屬性區別有哪些”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
相同之處
比如下面這個 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;
“兩個DOM屬性區別有哪些”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。