Javascript实现打鼓效果


Posted in Javascript onJanuary 29, 2021

本文实例为大家分享了Javascript实现打鼓效果的具体代码,供大家参考,具体内容如下

Javascript实现打鼓效果

按住响应的键盘显示不同的声音

<div class="keys">
  <div data-key="65" class="key">
   <kbd>A</kbd>
   <span class="sound">clap</span>
  </div>
  <div data-key="83" class="key">
   <kbd>S</kbd>
   <span class="sound">hihat</span>
  </div>
  <div data-key="68" class="key">
   <kbd>D</kbd>
   <span class="sound">kick</span>
  </div>
  <div data-key="70" class="key">
   <kbd>F</kbd>
   <span class="sound">openhat</span>
  </div>
  <div data-key="71" class="key">
   <kbd>G</kbd>
   <span class="sound">boom</span>
  </div>
  <div data-key="72" class="key">
   <kbd>H</kbd>
   <span class="sound">ride</span>
  </div>
  <div data-key="74" class="key">
   <kbd>J</kbd>
   <span class="sound">snare</span>
  </div>
  <div data-key="75" class="key">
   
   <kbd>K</kbd>
   <span class="sound">tom</span>
  </div>
  <div data-key="76" class="key">
   <kbd>L</kbd>
   <span class="sound">tink</span>
  </div>
  </div>
 
  <audio data-key="65" src="sounds/clap.wav"></audio>
  <audio data-key="83" src="sounds/hihat.wav"></audio>
  <audio data-key="68" src="sounds/kick.wav"></audio>
  <audio data-key="70" src="sounds/openhat.wav"></audio>
  <audio data-key="71" src="sounds/boom.wav"></audio>
  <audio data-key="72" src="sounds/ride.wav"></audio>
  <audio data-key="74" src="sounds/snare.wav"></audio>
  <audio data-key="75" src="sounds/tom.wav"></audio>
  <audio data-key="76" src="sounds/tink.wav"></audio>

css部分:

html {
 font-size: 10px;
 background: url('../img/background.jpg') bottom center;
 background-size: cover;
}

body,html {
 margin: 0;
 padding: 0;
 font-family: sans-serif;
}

.keys {
 display: flex;
 flex: 1;
 min-height: 100vh;
 align-items: center;
 justify-content: center;
}

.key {
 border: .4rem solid black;
 border-radius: .5rem;
 margin: 1rem;
 font-size: 1.5rem;
 padding: 1rem .5rem;
 transition: all .07s ease;
 width: 10rem;
 text-align: center;
 color: white;
 background: rgba(0,0,0,0.4);
 text-shadow: 0 0 .5rem black;
}

.playing {
 transform: scale(1.1);
 border-color: #ffc600;
 box-shadow: 0 0 1rem #ffc600;
}

kbd {
 display: block;
 font-size: 4rem;
}

.sound {
 font-size: 1.2rem;
 text-transform: uppercase;
 letter-spacing: .1rem;
 color: #ffc600;
}

第一步实现按下键盘实现,声音的播放

window.addEventListener("keydown",function(e){
   console.log(e.keyCode);
   const audio=document.querySelector(`audio[data-key="${e.keyCode}"]`);
   const key=document.querySelector(`div[data-key="${e.keyCode}"]`)
   //每次播放完初始化
    if (!audio) return;
    audio.currentTime = 0;
    audio.play();

     key.classList.add('playing');

     setTimeout(function(){
     key.classList.remove('playing');
     },70);
    
    //按键之后移出效果
})

keyCode对应图

Javascript实现打鼓效果

Javascript实现打鼓效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
总结一些js自定义的函数
Aug 05 Javascript
兼容IE和FF的图片上传前预览js代码
May 28 Javascript
js关于命名空间的函数实例
Feb 05 Javascript
JavaScript实现信用卡校验方法
Apr 07 Javascript
js实现div层缓慢收缩与展开的方法
May 11 Javascript
jQuery实现可展开合拢的手风琴面板菜单
Sep 15 Javascript
js实现div模拟模态对话框展现URL内容
May 27 Javascript
Bootstrap基本布局实现方法详解
Nov 25 Javascript
jquery中有哪些api jQuery主要API
Nov 20 jQuery
通过实例学习React中事件节流防抖
Jun 17 Javascript
Vue登录主页动态背景短视频制作
Sep 21 Javascript
详解node.js创建一个web服务器(Server)的详细步骤
Jan 15 Javascript
JS实现点击掉落特效
Jan 29 #Javascript
Javascript实现关闭广告效果
Jan 29 #Javascript
Vue 实例中使用$refs的注意事项
Jan 29 #Vue.js
vue 项目@change多个参数传值多个事件的操作
Jan 29 #Vue.js
vue 实现click同时传入事件对象和自定义参数
Jan 29 #Vue.js
聊聊vue 中的v-on参数问题
Jan 29 #Vue.js
vue集成一个支持图片缩放拖拽的富文本编辑器
Jan 29 #Vue.js
You might like
php流量统计功能的实现代码
2012/09/29 PHP
PHP获取浏览器信息类和客户端地理位置的2个方法
2014/04/24 PHP
一个非常完美的读写ini格式的PHP配置类分享
2015/02/12 PHP
在Mac OS上自行编译安装Apache服务器和PHP解释器
2015/12/24 PHP
Yii框架的路由配置方法分析
2019/09/09 PHP
Laravel 使用查询构造器配合原生sql语句查询的例子
2019/10/12 PHP
javascript算法题 求任意一个1-9位不重复的N位数在该组合中的大小排列序号
2012/07/21 Javascript
基于MVC3方式实现下拉列表联动(JQuery)
2013/09/02 Javascript
JS拖拽组件学习使用
2016/01/19 Javascript
JavaScript 动态三角函数实例详解
2017/01/08 Javascript
js字符串与Unicode编码互相转换
2017/05/17 Javascript
JavaScript实现QQ列表展开收缩扩展功能
2017/10/30 Javascript
详解微信小程序实现仿微信聊天界面(各种细节处理)
2019/02/17 Javascript
Vue使用Proxy监听所有接口状态的方法实现
2019/06/07 Javascript
layui table 获取分页 limit的方法
2019/09/20 Javascript
基于JavaScript伪随机正态分布代码实例
2019/11/07 Javascript
python将txt文件读入为np.array的方法
2018/10/30 Python
python 实现调用子文件下的模块方法
2018/12/07 Python
对python3中, print横向输出的方法详解
2019/01/28 Python
python 类的继承 实例方法.静态方法.类方法的代码解析
2019/08/23 Python
Python socket非阻塞模块应用示例
2019/09/12 Python
Pytorch提取模型特征向量保存至csv的例子
2020/01/03 Python
python网络爬虫实现发送短信验证码的方法
2021/02/25 Python
CSS3 二级导航菜单的制作的示例
2018/04/02 HTML / CSS
HTML5 canvas基本绘图之填充样式实现
2016/06/27 HTML / CSS
英国网上香水店:Fragrance Direct
2016/07/20 全球购物
weblogic面试题
2016/03/07 面试题
毕业生求职找工作的自我评价范文
2013/11/27 职场文书
大型活动策划方案
2014/01/12 职场文书
公司门卫岗位职责
2014/03/15 职场文书
男性健康日的活动方案
2014/08/18 职场文书
报考公务员诚信承诺书
2014/08/29 职场文书
庆祝教师节主题班会
2015/08/17 职场文书
php 原生分页
2021/04/01 PHP
基于Redis zSet实现滑动窗口对短信进行防刷限流的问题
2022/02/12 Redis
Python使用openpyxl模块处理Excel文件
2022/06/05 Python