Readonly与Disabled

Readonly和Disabled都是用在表单中的两个属性;

作用:都能够做到使用户不能够更改表单域中的内容。

(一)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();// 子窗口关闭后刷新父窗口
 }

2.easyui-combobox\ easyui-searchbox禁止下拉操作

// $("#updateTranRef").attr("readonly","readonly"); //收据号
$("#updateCcy").combobox("disable");// 币种
$("#updateFmCode").combobox("disable"); // 交割方式
$("#updateCmCode").searchbox('textbox').attr('disabled',true); // 客户代码

 

posted @ 2017-02-17 21:07  Mxzer.Zhang  阅读(315)  评论(0编辑  收藏  举报