实现一个弹幕墙APP

弹幕墙APP点这里

功能: 实现发射弹幕、清除弹幕、显示弹幕功能。
扩展:野狗实时后端云来存储弹幕数据。

按照 : 结构-->样式-->功能-->存储 进行开发

结构和样式很简单:


这里注意由于要实现弹幕滚动要用到绝对定位,然后动态改变弹幕 left 的值。这里用到绝对定位元素的居中。

由于绝对定位脱离了文档流,所以用 text-align:centermargin: 0 auto实现不了水平居中,这里要用到一种比较暴力的方法

position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;

就是使其既向上也向下,既向上又向下。这样它就不知所措,所以就乖乖的呆在中间了233

还有一种方法,用到css3的 transform 方法

position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);

就是先相对于父元素偏移50%,再使自己相对于自己移动50%。不知道为什么这种方法我没实现。

最重要的 功能

//创建数据库引用
var config = {
    authDomain: "sxydanmu.wilddog.com",
    syncURL: "https://sxydanmu.wilddogio.com"
  };
  wilddog.initializeApp(config);
  var ref = wilddog.sync().ref();
//发射按钮事件
  $("#shut").click(function() {
    var text = $(".s_txt").val();//获取输入框文字
    ref.child('message').push(text);// 将数据写到云端 message 节点下,child 用来定位子节点
    $(".s_txt").val('');//清空输入框
  });
//清空按钮事件
  $("#clc").click(function() {
    ref.remove();//清空云端数据
    arr = [];
    $(".move").empty();//清空显示框
  });
// 绑定 'child_added' 事件,当 message 节点下有子节点新增时,就会触发回调,回调的 `snapshot` 对象包含了新增的数据
  ref.child('message').on('child_added', function(snapshot) {
    var text = snapshot.val();
    arr.push(text);
    var textObj = $("<div></div>");
    textObj.text(text);
    $(".move").append(textObj);
    moveObj(textObj);
    console.log(text);
  });
//清屏后清空云端数据,清空本地弹幕
  ref.on('child_removed', function(snapshot) {
    arr = [];
    $(".show").empty();
  });
//弹幕滚动及逐条显示
var topMin = $('.message').offset().top;     // 显示框距顶部距离
  var topMax = topMin + $('.message').height(); // 显示框底部距顶部距离
  var _top = topMin; // 每个滚动消息距顶部距离
  var moveObj = function(obj) {
    var _left = $('.message').width() - obj.width();
    _top = _top + 50;
    if (_top > (topMax - 50)) {
        _top = topMin;
    }
    obj.css({
        left : _left,
        top : _top,
        color : getRandomColor()  // 获取随机颜色
    });
    var time = 20000 + 10000 * Math.random();
    // animate() 方法执行 CSS 属性集的自定义动画。逐渐改变的,这样就可以创建动画效果。
    obj.animate({
        left : "-" + _left + "px"  // 让消息距左距离逐渐减小,产生右向左滚动动画。
    }, time, function() {
        obj.remove();
    });
  }
//在屏幕上输出弹幕
  var getAndRun = function() { //弹幕输出
    if (arr.length > 0) {
        var n = Math.floor(Math.random() * arr.length + 1) - 1;
        var textObj = $("<div>" + arr[n] + "</div>");
        $(".move").append(textObj);
        moveObj(textObj);
    }
    setTimeout(getAndRun, 3000);
  }
//随机颜色函数
var getRandomColor = function() {//随机颜色函数
    return '#' + (function(h) {
        return new Array(7 - h.length).join("0") + h
    })((Math.random() * 0x1000000 << 0).toString(16))
  }

大致就是这么多了,其实照着文档写倒也没花太多功夫。

写了这个弹幕APP,让我学会了写JQuery,之前一直写原生的JS,果然JQuery方便的多。不过我觉得我还是喜欢写原生的(我是不是有病)

css3动画这方面需要了解,有空要看看,其他倒没有什么大问题了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,747评论 1 92
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,039评论 25 707
  • Swift版本点击这里欢迎加入QQ群交流: 594119878最新更新日期:18-09-17 About A cu...
    ylgwhyh阅读 25,361评论 7 249
  • 在过去很长一段时间,我对“直播”这两个字是很抗拒的,甚至嗤之以鼻,因为一想到这两字我脑海里浮现的总是那些很low的...
    无恙不young阅读 238评论 0 0
  • 我知道在我眼里那些最伟大的人,正如我知道那些最伟大的人眼里最伟大的我一样。 那些伟大的人,他们有两只眼睛,那些...
    可怕的军队阅读 277评论 0 0