Javascript禁用输入字段

时间:2015-12-14 22:58:40

标签: javascript jquery html

我有两个输入字段,一个是电话号码,另一个是电子邮件。我想根据用户选择禁用一个字段。如果用户在任一字段中单击并输入输入,则会禁用另一个字段,反之亦然。

我已编写代码,但似乎只在电话字段中输入数字时禁用电子邮件字段。删除电话字段中的号码会从电子邮件输入字段中删除已禁用的号码。

在我的HTML中

 <input type="number" name="number" placeholder="hone" class="cellphone" data-cp-visibility="new-user" id="phone">

 <input type="email" name="email" placeholder="enter email" class="email" data-cp-visibility="new-user" id="email">

IN JAVASCRIPT

 $('#phone').live('blur',function(){ 
     if(document.getElementById('phone').value > 1) {
        $('#email').attr('disabled', true);
      } else {
       $('#email').attr('disabled', false);
  }
 });

$('#email').live('blur',function(){ 
   if(document.getElementById('email').value > 1) {
    $('#phone').attr('disabled', true);
     } else {
       $('#phone').attr('disabled', false);
   }
});

最终我想要完成的是用户可以在任一字段中单击然后输入输入,这样做时,另一个字段被禁用。如果他们选择删除他们输入的文本,它将删除已禁用的功能,然后他们可以选择相反的输入字段。

我不确定为什么它仅适用于一个字段而不适用于另一个字段,或者为什么如果您在电话字段中输入333-333-3333它会中断已禁用,但33333333正常工作。

关于我可能遗失的任何想法或见解?

3 个答案:

答案 0 :(得分:0)

您可以使用jQuery on代替live。 live从jQuery 1.7开始被弃用。 您还可以在输入元素上查找keyup / keydown事件。

$(function(){

   $('#phone').on('keyup',function(){ 

      if($(this).val()!=="") 
      {
        $('#email').prop('disabled', true);
      }
      else {
        $('#email').attr('disabled', false);
      }
   });

   $('#email').on('keyup',function(){ 

      if($(this).val()!=="") 
      { 
         $('#phone').prop('disabled', true);
      }
      else {
          $('#phone').prop('disabled', false);
      }
  });      

});

Here是一个工作样本。

答案 1 :(得分:0)

我建议使用.on('input', ...)来监听更改,这样即使你使用递增/递减按钮(或其他形式的输入),你也会触发事件处理程序。然后使用.attr('disabled', boolean)来控制启用/禁用状态,请参阅下面的示例:

&#13;
&#13;
$(function() {
  $('#phone').on('input', function() {
    $('#email').attr('disabled', $(this).val() !== "");
  });
  $('#email').on('input', function() {
    $('#phone').attr('disabled', $(this).val() !== "");
  });
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="number" placeholder="phone" id="phone">
<input type="email" placeholder="enter email" id="email">
&#13;
&#13;
&#13;

答案 2 :(得分:0)

要修复手机输入时出现的短划线问题,您可以尝试将其更改为:

<input type="text" required="" pattern="\d{3}[\-]\d{3}[\-]\d{4}" name="phone" id="phone"  data-cp-visibility="new-user" placeholder="123-345-5678">

这是另一个版本的js:

var $phone = $('#phone'),
    $email = $('#email');

$phone.on('keyup change', function() {

   $email.prop('disabled', $(this).val() ? true : false );

});

$email.on('keyup change', function() {

    $phone.prop('disabled', $(this).val() ? true : false );

});