Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 92b6307

Browse files
author
Stefan Bauckmeier
committed
01 done
1 parent 38a754c commit 92b6307

File tree

1 file changed

+35
-27
lines changed

1 file changed

+35
-27
lines changed

01 - JavaScript Drum Kit/index.html

Lines changed: 35 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -6,77 +6,85 @@
66
<link rel="stylesheet" href="style.css">
77
</head>
88
<body>
9-
10-
119
<div class="keys">
1210
<div data-key="65" class="key">
1311
<kbd>A</kbd>
1412
<span class="sound">clap</span>
13+
<audio src="sounds/clap.wav"></audio>
1514
</div>
1615
<div data-key="83" class="key">
1716
<kbd>S</kbd>
1817
<span class="sound">hihat</span>
18+
<audio src="sounds/hihat.wav"></audio>
1919
</div>
2020
<div data-key="68" class="key">
2121
<kbd>D</kbd>
2222
<span class="sound">kick</span>
23+
<audio src="sounds/kick.wav"></audio>
2324
</div>
2425
<div data-key="70" class="key">
2526
<kbd>F</kbd>
2627
<span class="sound">openhat</span>
28+
<audio src="sounds/openhat.wav"></audio>
2729
</div>
2830
<div data-key="71" class="key">
2931
<kbd>G</kbd>
3032
<span class="sound">boom</span>
33+
<audio src="sounds/boom.wav"></audio>
3134
</div>
3235
<div data-key="72" class="key">
3336
<kbd>H</kbd>
3437
<span class="sound">ride</span>
38+
<audio src="sounds/ride.wav"></audio>
3539
</div>
3640
<div data-key="74" class="key">
3741
<kbd>J</kbd>
3842
<span class="sound">snare</span>
43+
<audio src="sounds/snare.wav"></audio>
3944
</div>
4045
<div data-key="75" class="key">
4146
<kbd>K</kbd>
4247
<span class="sound">tom</span>
48+
<audio src="sounds/tom.wav"></audio>
4349
</div>
4450
<div data-key="76" class="key">
4551
<kbd>L</kbd>
4652
<span class="sound">tink</span>
53+
<audio src="sounds/tink.wav"></audio>
4754
</div>
4855
</div>
4956

50-
<audio data-key="65" src="sounds/clap.wav"></audio>
51-
<audio data-key="83" src="sounds/hihat.wav"></audio>
52-
<audio data-key="68" src="sounds/kick.wav"></audio>
53-
<audio data-key="70" src="sounds/openhat.wav"></audio>
54-
<audio data-key="71" src="sounds/boom.wav"></audio>
55-
<audio data-key="72" src="sounds/ride.wav"></audio>
56-
<audio data-key="74" src="sounds/snare.wav"></audio>
57-
<audio data-key="75" src="sounds/tom.wav"></audio>
58-
<audio data-key="76" src="sounds/tink.wav"></audio>
59-
6057
<script>
6158

59+
let keySounds = [];
60+
const soundElements = document.getElementsByClassName('key');
61+
Array.prototype.forEach.call(soundElements, function(element) {
62+
keySounds[element.dataset.key] = element;
63+
});
64+
65+
window.addEventListener('keydown', function(event){
66+
const soundElement = keySounds[event.keyCode];
67+
if (!soundElement) { return };
68+
69+
const audioElement = soundElement.getElementsByTagName('audio')[0];
70+
if (!audioElement) { return };
6271

63-
function playSound(e) {
64-
const audio = document.querySelector(`audio[data-key="${e.keyCode}"]`);
65-
const key = document.querySelector(`.key[data-key="${e.keyCode}"]`);
66-
if (!audio) return; // stop the function from running all together
67-
audio.currentTime = 0; // rewind to the start
68-
audio.play();
69-
key.classList.add('playing');
70-
}
71-
function removeTransition(e) {
72-
if (e.propertyName !== 'transform') return; // skip it if it's not a transform
73-
this.classList.remove('playing');
74-
}
72+
showSoundIsPlayingOn(soundElement);
73+
playAudioElement(audioElement)
74+
});
7575

76-
const keys = document.querySelectorAll('.key');
77-
keys.forEach(key => key.addEventListener('transitionend', removeTransition));
78-
window.addEventListener('keydown', playSound);
76+
function showSoundIsPlayingOn(soundElement) {
77+
soundElement.classList.add('playing');
78+
soundElement.addEventListener('transitionend', function(event) {
79+
if (event.propertyName == 'transform') { return; }
80+
event.currentTarget.classList.remove('playing');
81+
});
82+
}
7983

84+
function playAudioElement(audioElement) {
85+
audioElement.currentTime = 0;
86+
audioElement.play();
87+
}
8088
</script>
8189

8290
</body>

0 commit comments

Comments
 (0)