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