ユーザーに情報を入力するように求める小さなアプリを開発しています。入力フィールドにテキストヒントを表示したい。これをforループで行います...ページが読み込まれると、ヒントは正しく表示されますが、「フォーカス」イベントと「ぼかし」イベントでは何も起こりません...
jsコードで「forループ」を使用しないと、すべてがうまくいくので、なぜだろうと思っています...
ちなみに、私が for ループを使用する理由は、「DRY」の原則に従って自分自身を繰り返したくないからです...
助けてくれてありがとう!
LP
コードは次のとおりです。
<script src="/javascripts/jquery.js" type="text/javascript"></script>
<script type="text/javascript">
var form_elements = ['#submission_url', '#submission_email', '#submission_twitter']
var text_hints = ['Website Address', 'Email Address', 'Twitter Username (optional)']
$(document).ready(function(){
for(i=0; i<3; i++) {
$(form_elements[i]).val(text_hints[i]);
$(form_elements[i]).focus(function(i){
if ($(this).val() == text_hints[i]) {
$(this).val('');
}
});
$(form_elements[i]).blur(function(i){
if ($(this).val() != text_hints[i]) {
$(this).val(text_hints[i]);
}
});
}
});
</script>