javascript實(shí)現(xiàn)彈幕墻效果
剛開始入門前端,想仿照FreeCodeCamp中的一個(gè)項(xiàng)目制作簡單的彈幕墻。
步驟如下:
1、編寫HTML代碼:
創(chuàng)建一個(gè)彈幕顯示墻,以及兩個(gè)按鈕,分別為“發(fā)送”和“清屏”,并在文本框中設(shè)置placeholder為“說點(diǎn)什么吧?”以提示用戶在此輸入彈幕信息。
<body> <div class="con"> <div id="screen"> <div class="dm_show"> <!-- <div>text message</div> --> </div> </div> <div class="edit"> <p> <input placeholder="說點(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、編寫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)容清除,以便用戶下一次輸入 $('.content').val(''); //將文本框內(nèi)容用div包裹起來,便于后續(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è)簡易的彈幕墻就完成了,因本人經(jīng)驗(yàn)有限,所以彈幕墻還比較粗糙,還請各位批評(píng)指正。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
es6中class類靜態(tài)方法,靜態(tài)屬性,實(shí)例屬性,實(shí)例方法的理解與應(yīng)用分析
這篇文章主要介紹了es6中class類靜態(tài)方法,靜態(tài)屬性,實(shí)例屬性,實(shí)例方法的理解與應(yīng)用,結(jié)合實(shí)例形式分析了es6 class類靜態(tài)方法,靜態(tài)屬性,實(shí)例屬性,實(shí)例方法相關(guān)概念、原理、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2020-02-02js 創(chuàng)建一個(gè)浮動(dòng)div的代碼
js 創(chuàng)建一個(gè)浮動(dòng)div的代碼,一般用來指導(dǎo)用戶下面的操作與多條件選擇。點(diǎn)擊一下就可顯示,具體的大家可以自由發(fā)揮。2009-12-12ES6 javascript中class類的get與set用法實(shí)例分析
這篇文章主要介紹了ES6 javascript中class類的get與set用法,結(jié)合具體實(shí)例形式分析了ES6中類的get與set關(guān)鍵字使用方法,需要的朋友可以參考下2017-10-10原生JavaScript實(shí)現(xiàn)連連看游戲(附源碼)
原生JavaScript版連連看游戲,有源碼,適合初學(xué)者學(xué)習(xí),喜歡的朋友可以研究下2013-11-11JS常用的幾種數(shù)組遍歷方式以及性能分析對(duì)比實(shí)例詳解
這篇文章主要介紹了JS常用的幾種數(shù)組遍歷方式以及性能分析對(duì)比,結(jié)合實(shí)例形式詳細(xì)分析了javascript針對(duì)數(shù)組遍歷的幾種常見使用方法及執(zhí)行效率對(duì)比,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2018-04-04JavaScript實(shí)現(xiàn)下載超大文件的方法詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript中實(shí)現(xiàn)下載超大文件的相關(guān)方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03微信小程序三級(jí)聯(lián)動(dòng)選擇器使用方法
這篇文章主要為大家詳細(xì)介紹了微信小程序三級(jí)聯(lián)動(dòng)選擇器使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02微信小程序使用echarts獲取數(shù)據(jù)并生成折線圖
這篇文章主要介紹了微信小程序使用echarts獲取數(shù)據(jù)并生成折線圖,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10