為什麼要特別提textarea?因為其實textarea這個節點很特殊。而因為這個節點特殊,所以在IE和其它浏覽器下,對它的解釋不一樣。
賣一下關子,哈哈!其實主要原因是今天幫一個師兄修一個BUG,具體是因為從服務器拉數據下來插進textarea的時候失敗,這個情況只在IE出現。其它浏覽器一切正常!
首先,為什麼textarea特殊?在所有的表單插件裡面,textarea的值是寫在兩個開閉標簽之間的,所以它的值在DOM的角度可以看作是文本節點,這是textarea特有的。也正因為這個特性,所以當你修改它的innerHTML的值時你仍然可以改變textarea的文本,而IE雖然支持這樣做,卻不允許一件事:動態插入一些html標簽。
你不妨做一個實驗:
在IE下通過JS插入一段HTML代碼,用的是innerHTML屬性而不是value或者innerText。
IE9+我是沒有去測試,但是IE6、7、8都會報錯。
估計是出於安全的原因,所以才不允許JS動態插入html進textarea,但細心的人可以發現,其實如果你手動鍵入html代碼的話,textarea是可以接受的。我想其實這經歷了這樣一個過程:字符轉義。對的,這是唯一能夠解釋手動輸入html代碼成功的原因了。
所以,在我看來,既然那麼多的浏覽器的textarea都不支持html的顯示,為何JS操作的時候還要用innerHTML屬性呢?也就是說無論你用value插入html代碼還是用innerHTML插入html代碼,它都不會解析後顯示(所以才會有富文本編輯器代替textarea),那麼為什麼不用value去設置textarea的值呢?
所以我認為,設置textarea的值不應該通過innerHTML(當然更不可能是innerText,因為firefox的原因),而要通過value去設置。這一點是開發人員要注意的。因為最近看的一些童鞋的代碼老喜歡用innerHTML。其實我認為這都是要分場合的。