jQuery实现简单弹幕制作

在现在的视频网站,我们在看视频的时候经常会有弹幕出现,那么怎么通过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>

最终效果如下

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

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

以上是 jQuery实现简单弹幕制作 的全部内容, 来源链接: utcz.com/p/219073.html

回到顶部