亲宝软件园·资讯

展开

jQuery实现简单弹幕制作

cody0622 人气:0

在现在的视频网站,我们在看视频的时候经常会有弹幕出现,那么怎么通过js实现这一效果呢,下面介绍一种简单的方法。

首先,搭好结构:

页面中先放一个视频,视频下部放一个input 标签和button按钮,代码如下:

<div class="box">
    <div class="top">
      <video src="./static/梦然-少年 .mp4" controls autoplay muted></audio>
    </div>
<div class="foot">
  <input type="text" name="" id="text">
  <input type="button" value="发送" id="btn">
</div>
</div>

再来写js

首先,我们需要包装三个函数,也就是发送到弹幕的随机颜色、随机高度和随机字体大小;代码如下:

<script>
    //随机获取字体颜色函数
  function getRandomColor(){
    var r = Math.floor(Math.random()*255);
    var g = Math.floor(Math.random()*255);
    var b = Math.floor(Math.random()*255);
    return 'rgb('+r+','+g+','+ b +')'
  }
//随机获取高度函数
  function getRandomHeight(){
    var height = $('.top').height()
    return Math.random()*height-30
  }
//随机获取字体大小函数
  function getRandomFontSize(){
    return Math.floor(Math.random()*60)
  }

现在我们需要获取用户输入的内容在将内容显示到页面中,并且移动,一直到页面外就消除,代码如下:

 //事件注册
$('#btn').on('click',function(){
if($('#text').val() ==''){
  return
}
  $('<span></span>').text($('#text').val()).css({
    'position':'absolute',
    'width':200,
    'height':50,
    'color':getRandomColor(),
    'fontSize':getRandomFontSize(),
    'right':-200,
    'top':getRandomHeight()
  }).animate({right:1000},10000,'linear',function(){
   $(this).remove()
  }).appendTo($('.top'))
  $('#text').val('')
})

最后将键盘回车键也绑定事件,让用户输入内容后按下回车键和按发送按钮有同样的效果:

$('#text').keydown(function(event){
  if($('#text').val() ==''){
  return
} 
if(event.keyCode == 13){
  $('#btn').click()
}

})

</script>

最终效果如下

那么,现在一个简单的弹幕就制作完成了。

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

加载全部内容

相关教程
猜你喜欢
用户评论