javascript實(shí)現(xiàn)彈幕墻效果
剛開(kāi)始入門(mén)前端,想仿照FreeCodeCamp中的一個(gè)項(xiàng)目制作簡(jiǎn)單的彈幕墻。
步驟如下:
1、編寫(xiě)HTML代碼:
創(chuàng)建一個(gè)彈幕顯示墻,以及兩個(gè)按鈕,分別為“發(fā)送”和“清屏”,并在文本框中設(shè)置placeholder為“說(shuō)點(diǎn)什么吧?”以提示用戶(hù)在此輸入彈幕信息。
<body>
<div class="con">
<div id="screen">
<div class="dm_show">
<!-- <div>text message</div> -->
</div>
</div>
<div class="edit">
<p>
<input placeholder="說(shuō)點(diǎn)什么吧?" class="content" type="text" />
</p>
<p>
<input type="button" class="send" value="發(fā)送" />
<input type="button" class="clear" value="清屏" />
</p>
</div>
</div>
</body>
2、設(shè)置各標(biāo)簽的CSS樣式:
<style>
.con {
background-color: floralwhite;
padding: 40px 80px 80px;
}
#screen {
background-color: #fff;
width: 100%;
height: 380px;
border: 1px solid rgb(229, 229, 229);
font-size: 14px;
}
.content {
border: 1px solid rgb(204, 204, 204);
border-radius: 3px;
width: 320px;
height: 35px;
font-size: 14px;
margin-top: 30px;
}
.send {
border: 1px solid rgb(230, 80, 30);
color: rgb(230, 80, 0);
border-radius: 3px;
text-align: center;
padding: 0;
height: 35px;
line-height: 35px;
font-size: 14px;
width: 159px;
background-color: white;
}
.clear {
border: 1px solid;
color: darkgray;
border-radius: 3px;
text-align: center;
padding: 0;
height: 35px;
line-height: 35px;
font-size: 14px;
width: 159px;
background-color: white;
}
.edit {
margin: 20px;
text-align: center;
}
.text {
position: absolute;
}
*{
margin: 0;
padding: 0;
}
.dm_show{
margin: 30px;
}
</style>
CSS代碼完成后效果如下:
完成后的效果如下:

3、編寫(xiě)JavaScript代碼,添加按鈕點(diǎn)擊事件
<script type="text/javascript" src="../jquery-easyui-1.3.5/jquery.min.js"></script>
<script>
$(function() {
//設(shè)置“發(fā)送”按鈕點(diǎn)擊事件,將彈幕體顯示在彈幕墻上
$('.send').click(function() {
//獲取文本輸入框的內(nèi)容
var val = $('.content').val();
//將文本框的內(nèi)容賦值給val后,將文本框的內(nèi)容清除,以便用戶(hù)下一次輸入
$('.content').val('');
//將文本框內(nèi)容用div包裹起來(lái),便于后續(xù)處理
var $content = $('<div class="text">' + val + '</div>');
//獲取彈幕墻對(duì)象
$screen = $(document.getElementById("screen"));
//設(shè)置彈幕體出現(xiàn)時(shí)的上邊距,為任意值
var top = Math.random() * $screen.height()+40;
//設(shè)置彈幕體的上邊距和左邊距
$content.css({
top: top + "px",
left: 80
});
//將彈幕體添加到彈幕墻中
$('.dm_show').append($content);
//彈幕體從左端移動(dòng)到最右側(cè),時(shí)間為8秒,然后直接刪除該元素
$content.animate({
left: $screen.width()+80-$content.width()
}, 8000, function() {
$(this).remove();
});
});
//設(shè)置“清屏”點(diǎn)擊事件,清除彈幕墻中的所有內(nèi)容
$('.clear').click(function() {
$('.dm_show').empty();
});
});
</script>
最終效果如下:

至此,一個(gè)簡(jiǎn)易的彈幕墻就完成了,因本人經(jīng)驗(yàn)有限,所以彈幕墻還比較粗糙,還請(qǐng)各位批評(píng)指正。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 簡(jiǎn)單實(shí)現(xiàn)JavaScript彈幕效果
- 基于JavaScript實(shí)現(xiàn)彈幕特效
- JS實(shí)現(xiàn)的視頻彈幕效果示例
- JavaScript直播評(píng)論發(fā)彈幕切圖功能點(diǎn)集合效果代碼
- 一篇文章教你學(xué)會(huì)js實(shí)現(xiàn)彈幕效果
- javascript實(shí)現(xiàn)視頻彈幕效果(兩個(gè)版本)
- js實(shí)現(xiàn)簡(jiǎn)易彈幕系統(tǒng)
- 原生js實(shí)現(xiàn)彈幕效果
- JS實(shí)現(xiàn)視頻彈幕效果
- JS實(shí)現(xiàn)彈幕小案例
相關(guān)文章
一個(gè)判斷搶購(gòu)時(shí)間是否到達(dá)的簡(jiǎn)單的js函數(shù)
這篇文章主要介紹了一個(gè)簡(jiǎn)單的判斷搶購(gòu)時(shí)間是否到達(dá)的js函數(shù),原理很簡(jiǎn)單,找到時(shí)鐘的id,計(jì)算數(shù)值,到達(dá)搶購(gòu)時(shí)間時(shí)執(zhí)行任務(wù),需要的朋友可以參考下2014-06-06
layui 監(jiān)聽(tīng)select選擇 獲取當(dāng)前select的ID名稱(chēng)方法
今天小編就為大家分享一篇layui 監(jiān)聽(tīng)select選擇 獲取當(dāng)前select的ID名稱(chēng)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
js學(xué)習(xí)總結(jié)之DOM2兼容處理順序問(wèn)題的解決方法
這篇文章主要為大家詳細(xì)介紹了DOM2兼容處理順序問(wèn)題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
uniapp頁(yè)面跳轉(zhuǎn)的五種方式總結(jié)
這篇文章主要給大家介紹了關(guān)于uniapp頁(yè)面跳轉(zhuǎn)的五種方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-03-03
javascript實(shí)現(xiàn)仿騰訊游戲選擇
這篇文章主要介紹了javascript實(shí)現(xiàn)仿騰訊游戲選擇,簡(jiǎn)單實(shí)現(xiàn)的下拉菜單二級(jí)聯(lián)動(dòng)效果,十分不錯(cuò),有需要的小伙伴可以參考下。2015-05-05
純CSS3代碼實(shí)現(xiàn)滑動(dòng)開(kāi)關(guān)效果
CSS33D炫酷左右滑動(dòng)開(kāi)關(guān)按鈕是一款非??岬腃SS3 3D開(kāi)關(guān)按鈕,點(diǎn)擊按鈕可以左右滑動(dòng),就像開(kāi)關(guān)打開(kāi)閉合一樣的效果,通過(guò)本篇文章給大家介紹純CSS3代碼實(shí)現(xiàn)滑動(dòng)開(kāi)關(guān)效果,需要的朋友可以參考下2015-08-08

