(一)Readonly只针对input(text / password)和textarea有效。
Disabled对于所有的表单元素都有效,包括select, radio, checkbox, button等。
但是表单元素若使用了disabled后,当我们将表单以POST或GET的方式提交的话,这个元素的值不会被传递出去(即后台获取不到该值);
而readonly会将该值传递出去(这种情况出现在我们将某个表单中的textarea元素设置为disabled或readonly,但是submit button却是可以使用的)。
所以:
1.在某个表单中为用户预填了某个唯一识别代码,不允许用户改动,但是在提交时需要传递该值,此时应该将它的属性设置为readonly。
2.提交了表单后需要等待信息的验证,此时就不允许用户再更改表单中的数据,而是只能够查看,由于disabled的作用元素范围大,所以此时应该使用disabled,但同时应该注意的是要将submit button提交按钮也disabled掉,否则只要用户按了这个按钮,如果在数据库操作页面中没有做完整性检测的话,数据库中的值就会被清除。
3.若表单中只有input(text/password)和textarea元素,在这种情况下可用readonly来代替disabled, 如果存在其他类型的元素,比如select,用户可以在重新改写值后按回车键进行提交(回车是默认的submit触发按键),就会发生 第2点所说的问题。可在用户按了提交按钮后,利用javascript将提交按钮disabled掉,这样可以防止网络条件比较差的环境下,用户反复点提交按钮导致数据冗余地存入数据库。
(二)使用
2.1 readonly可代替diabled,外加css样式(灰色背景色);
function getPtCode(){
var newValue = $(‘#ptCode2‘).combobox(‘getValue‘); //combox取值
if(newValue == "PP"){
$("#spMonthlyCard2").val("7555803748");
$(‘#spMonthlyCard2‘).attr("Readonly","Readonly");
$(‘#spMonthlyCard2‘).css("background-color","rgb(235, 235, 228)");
}else{
$("#spMonthlyCard2").val("");
$(‘#spMonthlyCard2‘).css("background-color","white");
$(‘#spMonthlyCard2‘).removeAttr("Readonly");
}
$(‘#updateform‘).form(‘load‘); //重新加载页面(即执行刷新)
// window.close();
// window.opener.location.reload();// 子窗口关闭后刷新父窗口
}