JS弹幕实现
来源:互联网 发布:推荐淘宝高达店 编辑:程序博客网 时间:2024/05/02 01:28
基于直播平台的流行,利用原生实现一下弹幕效果。
原文链接
实现原理
1、设置展示弹幕元素位置属性为relative
2、动态创建弹幕元素,位置属性设置absolute,left为展示宽度
3、随机设置弹幕元素top值
4、随机产生弹幕元素移动速率,修改left值
随机颜色
第一种实现let color = '#' + Math.floor(Math.random() * 0xffffff).toString(16);第二种实现let color = '#' + Math.floor(Math.random() * 16777215).toString(16);第三种实现let r = Math.floor(Math.random()*256);let g = Math.floor(Math.random()*256);let b = Math.floor(Math.random()*256);let color = `rgb(${r},${g},${b})`;
随机速率
50 * +Math.random().toFixed(2)
代码
//html<div class="container"> <div id="content" class="content"></div> <div class="content-opt"> <div id="content-text" class="content-text"></div> <div class="content-input"> <input id="text" type="text"> <button id="send">发送</button> </div> </div></div>//css* { box-sizing: border-box; outline: none;}p { margin: .5em; word-break: break-all;}.container { position: relative; width: 700px; height: 500px; margin: auto; padding-right: 200px;}.content { width: 100%; height: 100%; border: 1px solid #ccc;}.content-opt { position: absolute; top: 0; right: 0; width: 200px; height: 100%;}.content-text { height: calc(100% - 30px); margin-bottom: 30px; border: 1px solid #ccc; overflow: auto;}.content-input { position: absolute; bottom: 0; width: 100%; height: 30px; border: 1px solid #ccc;}.content-input input { width: 70%; padding: 2px; border-radius: 5px;}.content-input button { padding: 3px 10px; border: none; border-radius: 5px; background: rgb(90, 154, 214);}//js(function () { class Barrage { constructor(id) { this.domList = []; this.dom = document.querySelector('#' + id); if (this.dom.style.position == '' || this.dom.style.position == 'static') { this.dom.style.position = 'relative'; } this.dom.style.overflow = 'hidden'; let rect = this.dom.getBoundingClientRect(); this.domWidth = rect.right - rect.left; this.domHeight = rect.bottom - rect.top; } shoot(text) { let div = document.createElement('div'); div.style.position = 'absolute'; div.style.left = this.domWidth + 'px'; div.style.top = (this.domHeight - 20) * +Math.random().toFixed(2) + 'px'; div.style.whiteSpace = 'nowrap'; div.style.color = '#' + Math.floor(Math.random() * 256).toString(10); div.innerText = text; this.dom.appendChild(div); let roll = (timer) => { let now = +new Date(); roll.last = roll.last || now; roll.timer = roll.timer || timer; let left = div.offsetLeft; let rect = div.getBoundingClientRect(); if (left < (rect.left - rect.right)) { this.dom.removeChild(div); } else { if (now - roll.last >= roll.timer) { roll.last = now; left -= 3; div.style.left = left + 'px'; } requestAnimationFrame(roll); } } roll(50 * +Math.random().toFixed(2)); } } let barage = new Barrage('content'); function appendList(text) { let p = document.createElement('p'); p.innerText = text; document.querySelector('#content-text').appendChild(p); } document.querySelector('#send').onclick = () => { let text = document.querySelector('#text').value; barage.shoot(text); appendList(text); }; const textList = ['弹幕', '666', '233333333', 'javascript', 'html', 'css', '前端框架', 'Vue', 'React', 'Angular', '测试弹幕效果' ]; textList.forEach((s) => { barage.shoot(s); appendList(s); })})()
效果
阅读全文
0 0
- JS--实现弹幕效果
- JS弹幕实现
- js 实现简单的弹幕
- 纯js 实现弹幕效果
- 网页弹幕实现(PHP+JS)
- js弹幕
- 弹幕实现
- 弹幕实现
- iOS实现弹幕功能
- 手机弹幕实现
- Android弹幕效果实现
- cocos2dx-lua实现弹幕
- 弹幕的简单实现
- 弹幕效果实现
- Jquery实现弹幕效果
- Android弹幕效果实现
- 如何实现弹幕
- jquery实现弹幕效果
- cookie和session的区别
- 数据库左右(left,right)连接及多表连接(inner)
- 1023. 组个最小数 (20)
- 分享一个双面透明逐渐显示的shader
- mysql:mysql error:Access denied for user 'root'@'localhost' (using password: YES)
- JS弹幕实现
- vi 的使用
- 文章标题4.(4)
- python圣斗士修炼(五):常用的数据结构
- 我在聚宽共享函数一
- java概念的小问题总结(二)
- 硬币找零问题 动态规划问题
- 输出10个100以内的随机数(c实现)
- c++构造函数