2016-10-08 10 views
0

drupalでは、ユーザープロフィールフォームを編集するときに、パスワードフィールドをクリック(フォーカス)するとこのdivが表示されます。フォーカスが合っていないときにdivを表示しない

<div class="password-suggestions description" style="display: block;"> 
Security hints and tips : 
<ul><li>Tip #1 </li> 
<li>Tip #2</li></ul></div> 

インラインスタイルは、表示から非表示に切り替わります。
しかし、別の場所をクリックすると、スイッチバックされずに表示され、不必要な混乱がページに加えられます。

私は非常にjavascriptを知っているので、必要がないときはパスワード候補のdivを隠すためにいくつかの助けが必要です。 HTMLとjQueryコードは ")MyFunctionを(" 機能で入力フィールドにイベントをonfocusout追加してくださいセキュリティヒントDIV を隠すためにここ

 Drupal.behaviors.password = { 
     attach: function (context, settings) { 
     var translate = settings.password; 
     $('input.password-field', context).once('password', function() { 
      var passwordInput = $(this); 
      var innerWrapper = $(this).parent(); 
      var outerWrapper = $(this).parent().parent(); 

      // Add identifying class to password element parent. 
      innerWrapper.addClass('password-parent'); 

      // Add the password confirmation layer. 
      $('input.password-confirm', outerWrapper).parent().prepend('<div class="password-confirm">' + translate['confirmTitle'] + ' <span></span></div>').addClass('confirm-parent'); 
      var confirmInput = $('input.password-confirm', outerWrapper); 
      var confirmResult = $('div.password-confirm', outerWrapper); 
      var confirmChild = $('span', confirmResult); 

      // Add the description box. 
      var passwordMeter = '<div class="password-strength"><div class="password-strength-text" aria-live="assertive"></div><div class="password-strength-title">' + translate['strengthTitle'] + '</div><div class="password-indicator"><div class="indicator"></div></div></div>'; 
      $(confirmInput).parent().after('<div class="password-suggestions description"></div>'); 
      $(innerWrapper).prepend(passwordMeter); 
      var passwordDescription = $('div.password-suggestions', outerWrapper).hide(); 

      // Check the password strength. 
      var passwordCheck = function() { 

      // Evaluate the password strength. 
      var result = Drupal.evaluatePasswordStrength(passwordInput.val(), settings.password); 

      // Update the suggestions for how to improve the password. 
      if (passwordDescription.html() != result.message) { 
       passwordDescription.html(result.message); 
      } 

      // Only show the description box if there is a weakness in the password. 
      if (result.strength == 100) { 
       passwordDescription.hide(); 
      } 
      else { 
       passwordDescription.show(); 
      } 

      // Adjust the length of the strength indicator. 
      $(innerWrapper).find('.indicator').css('width', result.strength + '%'); 

      // Update the strength indication text. 
      $(innerWrapper).find('.password-strength-text').html(result.indicatorText); 

      passwordCheckMatch(); 
      }; 

      // Check that password and confirmation inputs match. 
      var passwordCheckMatch = function() { 

      if (confirmInput.val()) { 
       var success = passwordInput.val() === confirmInput.val(); 

       // Show the confirm result. 
       confirmResult.css({ visibility: 'visible' }); 

       // Remove the previous styling if any exists. 
       if (this.confirmClass) { 
       confirmChild.removeClass(this.confirmClass); 
       } 

       // Fill in the success message and set the class accordingly. 
       var confirmClass = success ? 'ok' : 'error'; 
       confirmChild.html(translate['confirm' + (success ? 'Success' : 'Failure')]).addClass(confirmClass); 
       this.confirmClass = confirmClass; 
      } 
      else { 
       confirmResult.css({ visibility: 'hidden' }); 
      } 
      }; 

      // Monitor keyup and blur events. 
      // Blur must be used because a mouse paste does not trigger keyup. 
      passwordInput.keyup(passwordCheck).focus(passwordCheck).blur(passwordCheck); 
      confirmInput.keyup(passwordCheckMatch).blur(passwordCheckMatch); 
     }); 
     } 
    }; 

答えて

1

ではなく、別の関数を定義し、属性を追加し、他の回答で、あなたは単に別の.blur()機能をチェーンなければならないように、

+0

あなたが提案したようなものを探していました。新しいものを追加するのではなく、既存のコードを編集するだけです。 – amstram

-1

はここでこれを処理JSですここでのサンプルコードでは、あなたのJSコードは

<!DOCTYPE html> 
 
<html> 
 
<head><script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script></head> 
 
<body> 
 

 
Password: <input type="password" id="fname" onfocusout="myFunction()"> 
 
<div class="password-suggestions description" style="display: block;"> 
 
Security hints and tips : 
 
<ul><li>Tip #1 </li> 
 
<li>Tip #2</li></ul></div> 
 

 

 
<script> 
 
function myFunction() { 
 
    $('div.password-suggestions').hide(); 
 
} 
 
</script> 
 

 
</body> 
 
</html>

です

passwordInput.keyup(passwordCheck).focus(passwordCheck).blur(passwordCheck).blur(function() { $('div.password-suggestions').hide(); }); :そうのような

function myFunction() { 
     $('div.password-suggestions').hide(); 
    } 

とhtmlコード

<input type="text" id="fname" onfocusout="myFunction()"> 
-1

CSSで非表示にすることができます

.password-suggestions:not(:focus) { 
    display: none !important; 
} 
関連する問題