基于jQuery实现弹幕APP


Posted in Javascript onFebruary 10, 2017

今天闲着无聊,写了个弹幕APP,主要实现以下几个功能:

1.点击“弹幕发射”或回车可以输出弹幕到弹幕墙上。
2.弹幕的运行轨迹是从弹幕墙的最右边到最左边,Y轴的数值在弹幕墙的高度内随机,颜色HEX随机,速度随机。
3.右侧的表格可以储存弹幕内容以及弹幕的发射时间,越靠近现在的越靠前。
4.点击“清除弹幕”可以把弹幕墙内的所有弹幕清除掉,但不会影响到表格中的数据。
5.如果弹幕长度过长(我设置的是6个字符),则超过规定长度之外的弹幕内容都会由“...”代替,并放入表格中。但弹幕墙中的内容依然是完整的。

基于jQuery实现弹幕APP

HTML代码:

<div class="frame"> 
 <div class="row"> 
 <div class="col-xs-8 col-sm-8 col-md-8 col-lg-8 danmu-box-frame"> 
 <div class="danmu-box"> 
 </div> 
 </div> 
 <div class="col-xs-4 col-sm-4 col-md-4 col-lg-4 danmu-table-frame"> 
 <table class="table .table-condensed danmu-table"> 
 <thead> 
  <tr> 
  <th> 
  弹幕内容 
  </th> 
  <th> 
  弹幕时间 
  </th> 
  </tr> 
 </thead> 
 <tbody> 
 </tbody> 
 </table> 
 </div> 
 </div> 
 <div class="danmu-form"> 
 <form class="form-inline"> 
 <input type="text" class="form-control" placeholder="开始吐槽!"> 
 <button type="button" class="btn btn-primary shoot"> 
 发射弹幕! 
 </button> 
 <button type="button" class="btn btn-danger clear"> 
 清空弹幕 
 </button> 
 </form> 
 </div> 
</div> 
<hr> 
<footer> 
 Designed By 
 <a href="http://blog.csdn.net/alenhhy" target="_blank"> 
 Alen Hu 
 </a> 
</footer>

*使用了Bootstrap3框架。

JQuery部分:

$(document).ready(function() { 
 $(".shoot").on("click", startDanmu); 
 $("form").keypress(function(event) { 
 if (event.keyCode === 13) { 
 event.preventDefault(); 
 startDanmu(); 
 } 
 }); 
 $(".clear").on("click", clearDanmu); 
}); 
 
//get random number in certain range 
function RandomNum(Min, Max) { 
 var Range = Max - Min; 
 var Rand = Math.random(); 
 var num = Min + Math.round(Rand * Range); 
 return num; 
} 
 
//time number add 0 before if <10 
function plusZero(x) { 
 if (x < 10) { 
 x = "0" + x; 
 } else { 
 x = x; 
 } 
 return x; 
} 
 
//start danmu 
function startDanmu() { 
 
 var message = $("input"); 
 var messageVal = message.val(); 
 var danmuMessage = "<span class='danmu-message'>" + messageVal + "</span>"; 
 
 //get random color HEX 
 //u can also save the colors u want by array 
 var color = RandomNum(100000, 999999); 
 
 //get random danmu speed 
 var speed = RandomNum(10000, 20000); 
 
 //get random position Y 
 //danmu box height is 450, we set the danmu position Y max 400 in case it blocks the subtitle 
 var positionY = RandomNum(50, 400); 
 
 if (messageVal.length > 0) { 
 //insert danmu message into danmu box 
 $(".danmu-box").prepend(danmuMessage); 
 
 //have to use first() cuz we prepend the message, u can try what's gonna happen if no first() 
 //set it's style 
 $(".danmu-message").first().css({ 
 "right": "0", 
 "top": positionY, 
 "color": "#" + color 
 }); 
 
 //set it's animation 
 //from right 0 to left 0 
 //hide it after move 
 $(".danmu-message").first().animate({ 
 left: '0px', 
 }, 
 speed, 
 function() { 
 $(this).fadeOut(); 
 }); 
 //get danmu time 
 var time = new Date(); 
 var month = time.getMonth() + 1; 
 var day = time.getDay(); 
 var hour = time.getHours(); 
 var minute = time.getMinutes(); 
 var danmuTime = plusZero(month) + "-" + plusZero(day) + " " + plusZero(hour) + ":" + plusZero(minute); 
 
 //insert danmu message to table 
 if (messageVal.length > 6) { 
 messageVal = messageVal.substring(0, 6) + "..."; 
 } 
 var messageToTable = "<tr><td>" + messageVal + "</td><td>" + danmuTime + "</td></tr>"; 
 $(".danmu-table > tbody").prepend(messageToTable); 
 
 } else {} 
 
 //empty the input 
 message.val(""); 
} 
 
//clear danmu box 
function clearDanmu() { 
 $(".danmu-box").html(""); 
}

DEMO在这儿,欢迎来FORK:Danmu APP。

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

Javascript 相关文章推荐
JavaScript 对话框和状态栏使用说明
Oct 25 Javascript
JavaScript访问样式表代码
Oct 15 Javascript
用jquery存取照片的具体实现方法
Jun 30 Javascript
在HTML代码中使用JavaScript代码的例子
Oct 16 Javascript
js实现飞入星星特效代码
Oct 17 Javascript
JS+CSS实现带小三角指引的滑动门效果
Sep 22 Javascript
详解JavaScript表单验证(E-mail 验证)
Mar 31 Javascript
AngularJS中关于ng-class指令的几种实现方式详解
Sep 17 Javascript
微信小程序获取微信运动步数的实例代码
Jul 20 Javascript
vue代理和跨域问题的解决
Jul 18 Javascript
Vue+abp微信扫码登录的实现代码示例
Jan 06 Javascript
详解Vue的异步更新实现原理
Dec 22 Vue.js
BOM之navigator对象和用户代理检测
Feb 10 #Javascript
基于JQuery及AJAX实现名人名言随机生成器
Feb 10 #Javascript
jQuery基于ajax方式实现用户名存在性检查功能示例
Feb 10 #Javascript
jQuery基于ajax实现页面加载后检查用户登录状态的方法
Feb 10 #Javascript
javascript自执行函数
Feb 10 #Javascript
完美解决jQuery的hover事件在IE中不停闪动的问题
Feb 10 #Javascript
jquery hover 不停闪动问题的解决方法(亦为stop()的使用)
Feb 10 #Javascript
You might like
PHP与SQL注入攻击[三]
2007/04/17 PHP
php 自写函数代码 获取关键字 去超链接
2010/02/08 PHP
PHP5中使用DOM控制XML实现代码
2010/05/07 PHP
PHP 多任务秒级定时器的实现方法
2018/05/13 PHP
使用upstart把nodejs应用封装为系统服务实例
2014/06/01 NodeJs
原生js实现tab选项卡切换
2020/03/23 Javascript
微信JSAPI支付操作需要注意的细节
2017/01/10 Javascript
bootstrap——bootstrapTable实现隐藏列的示例
2017/01/14 Javascript
React-Native做一个文本输入框组件的实现代码
2017/08/10 Javascript
JS/jQuery实现DIV延时几秒后消失或显示的方法
2018/02/12 jQuery
NodeJS加密解密及node-rsa加密解密用法详解
2018/10/12 NodeJs
详解如何搭建mpvue框架搭配vant组件库的小程序项目
2019/05/16 Javascript
vue 封装 Adminlte3组件的实现
2020/03/18 Javascript
微信小程序多列表渲染数据开关互不影响的实现
2020/06/05 Javascript
JavaScript实现网页留言板功能
2020/11/23 Javascript
JQuery绑定事件四种实现方法解析
2020/12/02 jQuery
pycharm 使用心得(一)安装和首次使用
2014/06/05 Python
Python中逗号的三种作用实例分析
2015/06/08 Python
python 3利用BeautifulSoup抓取div标签的方法示例
2017/05/28 Python
python批量实现Word文件转换为PDF文件
2018/03/15 Python
pandas series序列转化为星期几的实例
2018/04/11 Python
Python生成指定数量的优惠码实操内容
2019/06/18 Python
tensorflow实现将ckpt转pb文件的方法
2020/04/22 Python
使用Python-OpenCV消除图像中孤立的小区域操作
2020/07/05 Python
CSS3 实现倒计时效果
2020/11/25 HTML / CSS
Book Depository澳大利亚:世界领先的专业在线书店之一
2018/12/27 全球购物
EntityManager都有哪些方法
2013/11/01 面试题
机电一体化专业推荐信
2013/12/03 职场文书
影视制作岗位职责
2013/12/04 职场文书
生物学学生自我评价
2014/01/17 职场文书
骨干教师培训方案
2014/05/06 职场文书
刑事代理授权委托书
2014/09/17 职场文书
法人单位授权委托书范文
2014/10/06 职场文书
2015年暑期见闻
2015/07/14 职场文书
vue实现可拖拽的dialog弹框
2021/05/13 Vue.js
深入浅析Django MTV模式
2021/09/04 Python