2017-04-24 18 views
0

私はちょっと騒がしく、色のついたテキストボックスの16進コードに従って、サイトの背景色を即座に変更するようにJavaAcriptを作ろうとしています。送信ボタンを押したときに機能しますが、送信する必要はありません。事前にすぐにbgの色を変更してください

おかげ

$(function(){ 
    setInterval(changeBackground, 1); 
}); 



function changeBackground() { 
    // The working function for changing background color. 
    document.bgColor = document.getElementById("color").value; 
} 
+1

[ 'document.bgColor'](https://developer.mozilla.org/en-US/docs/Web/API/Document/bgColor)は本当に、古いです本当に古い。代わりに 'document.body.style.backgroundColor'を使用してください – Andreas

答えて

1

チェックアウトaddEventListenerinput eventaddEventListenerは、クリック、テキストボックス値の変更などのイベントに反応することができます。inputイベントは、ユーザーが問題の要素に何かを入力するたびに発生します。

var colorEl = document.getElementById('color'); 
 
colorEl.addEventListener('input', function() { 
 
    document.bgColor = colorEl.value; 
 
});
body { 
 
    width: 100%; 
 
    height: 100%; 
 
}
<input type="text" id="color" />

プロヒント:bgColorはもうこれを行うための好ましい方法ではありません。これは廃止されており、ブラウザでの動作は保証されていません。スタイリングするときはいつでもCSSを使う方がはるかに優れています。

document.style.backgroundColor = colorEl.value; 

するのではなく、ユーザは、次に入力すると別の場所にフォーカスを移動し終えるまで、あなたがchange eventを使用することができます待つしたい場合。

var colorEl = document.getElementById('color'); 
 
colorEl.addEventListener('change', function() { 
 
    document.bgColor = colorEl.value; 
 
});
body { 
 
    width: 100%; 
 
    height: 100%; 
 
}
<input type="text" id="color" />

2

あなたは、私は、コードを次のように行われてきたように、あなたの<input>onchangeイベントリスナーを割り当てる必要があり:

document.getElementById('color').addEventListener('change', changeBackground); 
0

アップイベントのキーを見てみてください

function changeBackground() { 
 
    document.bgColor = '#' + document.getElementById("color").value; 
 
}
<input id="color" onkeyup="changeBackground()" />

0

皆様におかれましてありがとうございます。

下記のCyril Beeckmanの提案はうまくいきましたが、すべて動作することがわかります。歓声

function changeBackground() { 
 
    document.bgColor = '#' + document.getElementById("color").value; 
 
}
<input id="color" onkeyup="changeBackground()" />

関連する問題