在现在的视频网站,我们在看视频的时候经常会有弹幕出现,那么怎么通过js实现这一效果呢,下面介绍一种简单的方法。
首先,搭好结构:
页面中先放一个视频,视频下部放一个input 标签和button按钮,代码如下:
1
2
3
4
5
6
7
8
9
|
< 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
首先,我们需要包装三个函数,也就是发送到弹幕的随机颜色、随机高度和随机字体大小;代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<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)
}
|
现在我们需要获取用户输入的内容在将内容显示到页面中,并且移动,一直到页面外就消除,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
//事件注册
$( '#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( '' )
})
|
最后将键盘回车键也绑定事件,让用户输入内容后按下回车键和按发送按钮有同样的效果:
1
2
3
4
5
6
7
8
9
10
11
|
$( '#text' ).keydown( function (event){
if ($( '#text' ).val() == '' ){
return
}
if (event.keyCode == 13){
$( '#btn' ).click()
}
})
</script>
|
最终效果如下
那么,现在一个简单的弹幕就制作完成了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/cody0622/article/details/110938467