readonly和disabled它們都能夠做到使用戶不能夠更改表單域中的內(nèi)容。但是它們之間有著微小的差別,總結(jié)如下:
readonly只針對input(text / password)和textarea有效,而disabled對于所有的表單元素都有效,但是表單元素在使用了disabled后,當(dāng)我們將表單以post或get的方式提交的話,這個元素的值不會被傳遞出去,而readonly會將該值傳遞出去(readonly接受值更改可以回傳,disable接受改但不回傳數(shù)據(jù))。
一般比較常用的情況是:
在某個表單中為用戶預(yù)填了某個唯一識別代碼,不允許用戶改動,但是在提交時需要傳遞該值,此時應(yīng)該將它的屬性設(shè)置為readonly 。
經(jīng)常遇到當(dāng)用戶正式提交了表單后需要等待管理員的信息驗證,這就不允許用戶再更改表單中的數(shù)據(jù),而是只能夠查看,由于disabled的作用元素范圍大,所以此時應(yīng)該使用disabled,但同時應(yīng)該注意的是要將submit button也disabled掉,否則只要用戶按了這個按鈕,如果在數(shù)據(jù)庫操作頁面中沒有做完整性檢測的話,數(shù)據(jù)庫中的值就會被清除。如果說在這種情況下用readonly來代替disabled的話,若表單中只有input(text / password)和textarea元素,那還是可以的,如果存在其他發(fā)元素,比如select,用戶可以在重新改寫值后按回車鍵進行提交(回車是默認的submit觸發(fā)按鍵)
我們常常在用戶按了提交按鈕后,利用javascript將提交按鈕disabled掉,這樣可以防止網(wǎng)絡(luò)條件比較差的環(huán)境下,用戶反復(fù)點提交按鈕導(dǎo)致數(shù)據(jù)冗余地存入數(shù)據(jù)庫。
disabled和readonly這兩個屬性有一些共同之處,比如都設(shè)為true,則form屬性將不能被編輯,往往在寫js代碼的時候容易混合使用這兩個屬性,其實他們之間是有一定區(qū)別的:
如果一個輸入項的disabled設(shè)為true,則該表單輸入項不能獲取焦點,用戶的所有操作(鼠標(biāo)點擊和鍵盤輸入等)對該輸入項都無效,最重要的一點是當(dāng)提交表單時,這個表單輸入項將不會被提交。
而readonly只是針對文本輸入框這類可以輸入文本的輸入項,如果設(shè)為true,用戶只是不能編輯對應(yīng)的文本,但是仍然可以聚焦焦點,并且在提交表單的時候,該輸入項會作為form的一項提交。