简单实现jQuery弹幕效果

发布时间 - 2026-01-11 01:00:05    点击率:

在要写一个弹幕案例的时候,首先要清楚每一步要干什么。
首先搭好框架之后在要发送弹幕时应该准备进行如下步骤:

  • 获取到要发送到弹幕上的内容,即获取到文本框输入的内容。通过jquery的var str = $(“#文本框的id”).val();
  • 生成一个元素:利用jQuery的 var createSpan =$(““)生成一个span元素,以便发送。
  • 给刚创建的span赋值,即获取到的文本框中的值 createSpan.text(str );
  • 设置元素的动画效果,是元素动起来。利用jQuery的animate(css样式值,时间, 执行完动画调用的方法)。执行完动画得手动移除刚刚所添加的元素。

里面还有许多细节,仔细看就会有收获!

<!DOCTYPE html>
<html>
<head>
<meta charset = "utf-8" />
 <title>弹幕案例</title>
 <script src = "http://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script>
 <script>
 $(function(){
 var boxDom = $("#boxDom");
 //var domContent = $("#domContent");

 var top, right;

 var pageWidth = parseInt($(document).width());
 var pageHeight =parseInt($(document).height());

 //点击按钮
 $("#btn").bind("click",auto);//按钮绑定方法
 //按下回车
 document.onkeydown = function(){
  if(event.keyCode == 13){
  auto();
  }
 }
 function auto(){
 //1.获取输入的字符串
 var str = $(".text").val();
 //2.生成一个元素
 var createSpan = $("<span class = 'string' ></span>");

 //3.给生成的元素赋值

 createSpan.text(str);

 //为了页面友好,清空刚刚输入的值
 $(".text").val("");

 //生成元素一个随机的位置,为了使每条弹幕都出现在屏幕上不同的位置
 top = Math.floor(Math.random()*pageHeight);


 createSpan.css({"top":top, "right": -400, "color": getRandomColor()});
 boxDom.append(createSpan);

 //4.设置元素的动画效果,animate(css样式值,时间, 执行完动画调用的方法)

 //页面上有N个span,只让最后一个动起来
 var spandom = $("#boxDom>span:last-child");//找到最后一个span
 spandom.animate({"right":pageWidth+300},10000,function(){
  //移除元素
  $(this).remove();

 });
 }
 //定义一个可以生成随机颜色的方法,可以使每条弹幕的颜色不同
 function getRandomColor(){
  var colorArr = ['1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'];
  var color = "";
  for(var i = 0; i < 6; i++){
  color += colorArr[Math.floor(Math.random()*16)]; 
  }
  return "#"+color;
 }

 });
 </script>
 <style type="text/css">
 html,body{
 margin: 0px;
 padding: 0px;
 width: 100%;
 height: 100%;
 font-family: "微软雅黑";
 background: #ccc;
 }
 .boxDom{
 width: 100%;
 height: 100%;
 position: relative;
 overflow: hidden;
 }
 .idDom{
 width: 100%;
 height: 60px;
 background:#666;
 position: fixed;
 bottom: 0px;
 }
 .contet{
 width: 500px;
 height: 40px;
 position: absolute;
 top: 0px;
 right: 0px;
 bottom: 0px;
 left: 0px;
 margin: auto;

 }
 .title{
 display: inline;
 font-size: 24px;
 vertical-align: bottom;
 color: #ffffff;
 padding-left: 300px;
 }

 .text{
 width: 300px;
 height: 30px;
 border:none;
 border-radius:5px;
 font-size: 20px;
 margin-left:60px;
 }
 .btn{
 width: 60px;
 height: 30px;
 color: #ffffff;
 background-color: red;
 border:none;
 font-size:16px;
 margin-left:60px;
 margin-top: 20px;
 }
 .string {
  width: 300px;
  height: 40px;
  margin-top: 20px;
  position: absolute;
  color: #000;
  font-size: 20px;
  font-family: "微软雅黑";

 }
 </style>
</head>
<body>
<div class = "boxDom" id = "boxDom">
 <img src="../images/bg_2.jpg" style="width:100%; height:100%" />
 <div id = "idDom" class = "idDom">
 <div class = "content">
  <p class = "title"> 说点什么:</p>
  <input type = "text" class = "text"/>
  <button type = "button" class = "btn" id = "btn" >发送</button>
 </div>
 </div>
</div>
</body>
</html>

效果图如下:

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


# jQuery  # 弹幕  # js实现七夕表白弹幕效果 jQuery实现弹幕技术  # jQuery实现简单弹幕制作  # jQuery实现弹幕特效  # jquery实现直播弹幕效果  # jQuery实现简单弹幕效果  # 基于jQuery实现弹幕APP  # 基于jquery实现弹幕效果  # 又一枚精彩的弹幕效果jQuery实现  # 终于实现了!精彩的jquery弹幕效果  # jQuery实现弹幕效果案例  # 微软  # 每条  # 移除  # 文本框  # 出现在  # 上有  # 按下  # 发送到  # 时应  # 绑定  # 仔细看  # 框中  # 大家多多  # 要写  # 清空  # 要干  # 说点  # 画得  # 搭好 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Linux安全能力提升路径_长期防护思维说明【指导】  怎么用AI帮你为初创公司进行市场定位分析?  java中使用zxing批量生成二维码立牌  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  Laravel如何使用Blade模板引擎?(完整语法和示例)  如何快速登录WAP自助建站平台?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制  Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】  详解jQuery停止动画——stop()方法的使用  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  浅谈Javascript中的Label语句  微信小程序 HTTPS报错整理常见问题及解决方案  Laravel怎么在Controller之外的地方验证数据  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  如何用JavaScript实现文本编辑器_光标和选区怎么处理  如何确保西部建站助手FTP传输的安全性?  Swift中swift中的switch 语句  如何用VPS主机快速搭建个人网站?  jQuery中的100个技巧汇总  高防服务器租用首荐平台,企业级优惠套餐快速部署  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  如何在IIS服务器上快速部署高效网站?  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  Laravel定时任务怎么设置_Laravel Crontab调度器配置  如何基于云服务器快速搭建网站及云盘系统?  Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】  微信推文制作网站有哪些,怎么做微信推文,急?  Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用  Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势  微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】  Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践  如何在IIS中新建站点并配置端口与IP地址?  Bootstrap整体框架之JavaScript插件架构  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  如何在Windows 2008云服务器安全搭建网站?  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  怎样使用JSON进行数据交换_它有什么限制  Laravel如何使用Service Container和依赖注入?(代码示例)  如何在 Pandas 中基于一列条件计算另一列的分组均值  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  如何用虚拟主机快速搭建网站?详细步骤解析  微信小程序制作网站有哪些,微信小程序需要做网站吗?  Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用  JavaScript实现Fly Bird小游戏