DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> HTML基礎知識 >> HTML和Xhtml >> 關於使用Textarea的注意事項
關於使用Textarea的注意事項
編輯:HTML和Xhtml     
為什麼要特別提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。其實我認為這都是要分場合的。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved