js 弹幕

该文章展示了如何使用HTML、CSS和JavaScript创建一个浮动字体大小和颜色不一的滚动弹幕效果。用户可以通过点击按钮发送新弹幕,底部的发送区域可收起和展开。在实现过程中,遇到了速度变量导致弹幕位置错误的问题,解决方法是确保每次发送新弹幕时重新初始化速度变量。
摘要由CSDN通过智能技术生成

效果展示

弹幕

需求分析
页面上漂浮字体大小不一、颜色不一,从左向右滚动的弹幕;
底部中间有一个发送功能,可以发送新的弹幕;
底部的发送部分可以向下收起和弹出。

原理实现
1、发送部分收起,弹出
onclick事件display转换
2、发送弹幕
点击事件发生时,创建一个对象,读取并保存text的内容
运用random函数随机获取大小和颜色
运用计时器改变弹幕的位置,直到超过一定距离移出该对象

遇到的bug
如果speed不在计时器内声明,那就是个比较大的变量,当再次点击时获取的大变量即上一个弹幕的位置,会出现弹幕不会重新从左往右,而是从上一个弹幕位置开始

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        .box{
            height: 100%;
            width: 100%;
            overflow: hidden;
        }
        .load{
            height: 600px;
            width: 100%;
            background-color: aqua;
        }
        .load span{
            position: absolute;
        }
        .bottom{
            height: 100px;
            width: 100%;
            background-color: coral;
            display: block;
        }
        .bottom input{
            margin-left: 600px;
            margin-top: 40px;
            height: 20px;
            width: 200px;
        }
        .bottom button{
            margin-left: 20px;
        }
        .flex{
            background-color: coral;
            display: none;
            height: 50px;
            width: 100%;
        }
        .flex button{
            height: 40px;
            width: 100px;
            line-height: 30px;
            font-size: 20px;
            text-align: center;
            margin-left: 700px;
            margin-top: 5px;
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="load">

        </div>
        <div class="bottom">
            <input type="text" placeholder="点击发送弹幕" class="inte">
            <button class="fire">点击发送</button>
            <button class="close">折叠</button>
        </div>
        <div class="flex">
            <button class="open">展开</button>
        </div>
    </div>
    <script>
        var color=["coral","aqua","gold","lightpink","black","yellow","red"]
        var colornum;
        var fontsize;
        var load=document.querySelector('.load')
        var but=document.querySelector('.bottom');
        var close=document.querySelector('.close');
        var but2=document.querySelector('.flex');
        var open=document.querySelector('.open');
        var fire=document.querySelector('.fire');
        var inte=document.querySelector('.inte')

        close.onclick=function(){
            but.style.display="none";
            but2.style.display="block";
        }
        open.onclick=function(){
            but.style.display="block";
            but2.style.display="none";
        }
        fire.onclick=function(){
            var ob=document.createElement('span');
            ob.innerHTML=inte.value;
            load.appendChild(ob);
            ob.style.color=color[Math.floor(Math.random()*7)];
            ob.style.fontsize=(Math.floor(Math.random()*8+15))+'px';
            ob.style.top=(Math.random()*500)+'px';
            var speed=0
            var timer=setInterval(function(){
                speed+=60
                ob.style.left=speed+'px'
                if(ob.offsetLeft>=1800){
                    clearInterval(timer)
                    load.removeChild(ob)
                }
            },300)
            inte.value=null
        }
    </script>
</body>
</html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,以下是使用JavaScript实现视频弹幕特效的基本步骤: 1. 获取视频播放器的DOM元素和弹幕容器的DOM元素 2. 定义弹幕内容的数据结构,例如: ``` var comments = [ { text: "第一条弹幕", time: 5 }, { text: "第二条弹幕", time: 10 }, { text: "第三条弹幕", time: 15 } ]; ``` 其中,text表示弹幕的文本内容,time表示弹幕出现的时间(单位为秒)。 3. 监听视频播放器的timeupdate事件,在每一帧视频播放时判断当前时间是否有对应的弹幕需要显示,如果有则创建一个弹幕元素,添加到弹幕容器中,并设置弹幕的样式和动画效果。 4. 为弹幕元素添加击事件,当用户弹幕时可以进行相应的操作,例如暂停视频播放、跳转到对应的时间等。 下面是一个简单的示例代码: ```javascript var video = document.getElementById("myVideo"); var commentContainer = document.getElementById("commentContainer"); var comments = [ { text: "第一条弹幕", time: 5 }, { text: "第二条弹幕", time: 10 }, { text: "第三条弹幕", time: 15 } ]; video.addEventListener("timeupdate", function() { var currentTime = video.currentTime; for (var i = 0; i < comments.length; i++) { if (currentTime >= comments[i].time) { var commentElement = document.createElement("div"); commentElement.className = "comment"; commentElement.textContent = comments[i].text; commentContainer.appendChild(commentElement); // 设置弹幕的样式和动画效果 // ... } } }); commentContainer.addEventListener("click", function(event) { // 处理弹幕击事件 // ... }); ``` 需要注意的是,弹幕的样式和动画效果可以使用CSS来实现,例如: ```css .comment { position: absolute; top: 50%; left: 100%; transform: translate(0, -50%); white-space: nowrap; animation: move 10s linear; } @keyframes move { 0% { transform: translate(100%, -50%); } 100% { transform: translate(-100%, -50%); } } ``` 这里使用了position属性来设置弹幕的位置,animation属性来设置弹幕的动画效果。具体的样式和动画效果可以根据需要进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

优降宁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值