Skip to content

Commit b5803f2

Browse files
SageEnvisionsSageEnvisions
SageEnvisions
authored and
SageEnvisions
committed
drum kit complete
1 parent 38a754c commit b5803f2

File tree

1 file changed

+19
-1
lines changed

1 file changed

+19
-1
lines changed

01 - JavaScript Drum Kit/index-START.html

Lines changed: 19 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,25 @@
5858
<audio data-key="76" src="sounds/tink.wav"></audio>
5959

6060
<script>
61-
61+
62+
function playSound(e) {
63+
const audio = document.querySelector(`audio[data-key="${e.keyCode}"]`);
64+
const key = document.querySelector(`.key[data-key="${e.keyCode}"]`);
65+
if(!audio) return; // stops the function
66+
audio.currentTime = 0; // rewind to the start
67+
audio.play();
68+
key.classList.add('playing');
69+
}
70+
71+
function removeTransition(e) {
72+
if (e.propertyName !== 'transform') return;
73+
this.classList.remove('playing');
74+
}
75+
76+
const keys = document.querySelectorAll('.key');
77+
keys.forEach(key => key.addEventListener('transitionend', removeTransition));
78+
window.addEventListener('keydown', playSound);
79+
6280
</script>
6381

6482

0 commit comments

Comments
 (0)