javascript實現(xiàn)彈幕墻效果
剛開始入門前端,想仿照FreeCodeCamp中的一個項目制作簡單的彈幕墻。
步驟如下:
1、編寫HTML代碼:
創(chuàng)建一個彈幕顯示墻,以及兩個按鈕,分別為“發(fā)送”和“清屏”,并在文本框中設(shè)置placeholder為“說點什么吧?”以提示用戶在此輸入彈幕信息。
<body> <div class="con"> <div id="screen"> <div class="dm_show"> <!-- <div>text message</div> --> </div> </div> <div class="edit"> <p> <input placeholder="說點什么吧?" 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è)置各標簽的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代碼,添加按鈕點擊事件
<script type="text/javascript" src="../jquery-easyui-1.3.5/jquery.min.js"></script> <script> $(function() { //設(shè)置“發(fā)送”按鈕點擊事件,將彈幕體顯示在彈幕墻上 $('.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>'); //獲取彈幕墻對象 $screen = $(document.getElementById("screen")); //設(shè)置彈幕體出現(xiàn)時的上邊距,為任意值 var top = Math.random() * $screen.height()+40; //設(shè)置彈幕體的上邊距和左邊距 $content.css({ top: top + "px", left: 80 }); //將彈幕體添加到彈幕墻中 $('.dm_show').append($content); //彈幕體從左端移動到最右側(cè),時間為8秒,然后直接刪除該元素 $content.animate({ left: $screen.width()+80-$content.width() }, 8000, function() { $(this).remove(); }); }); //設(shè)置“清屏”點擊事件,清除彈幕墻中的所有內(nèi)容 $('.clear').click(function() { $('.dm_show').empty(); }); }); </script>
最終效果如下:
至此,一個簡易的彈幕墻就完成了,因本人經(jīng)驗有限,所以彈幕墻還比較粗糙,還請各位批評指正。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
es6中class類靜態(tài)方法,靜態(tài)屬性,實例屬性,實例方法的理解與應(yīng)用分析
這篇文章主要介紹了es6中class類靜態(tài)方法,靜態(tài)屬性,實例屬性,實例方法的理解與應(yīng)用,結(jié)合實例形式分析了es6 class類靜態(tài)方法,靜態(tài)屬性,實例屬性,實例方法相關(guān)概念、原理、用法及相關(guān)操作注意事項,需要的朋友可以參考下2020-02-02ES6 javascript中class類的get與set用法實例分析
這篇文章主要介紹了ES6 javascript中class類的get與set用法,結(jié)合具體實例形式分析了ES6中類的get與set關(guān)鍵字使用方法,需要的朋友可以參考下2017-10-10原生JavaScript實現(xiàn)連連看游戲(附源碼)
原生JavaScript版連連看游戲,有源碼,適合初學者學習,喜歡的朋友可以研究下2013-11-11JS常用的幾種數(shù)組遍歷方式以及性能分析對比實例詳解
這篇文章主要介紹了JS常用的幾種數(shù)組遍歷方式以及性能分析對比,結(jié)合實例形式詳細分析了javascript針對數(shù)組遍歷的幾種常見使用方法及執(zhí)行效率對比,具有一定參考借鑒價值,需要的朋友可以參考下2018-04-04微信小程序使用echarts獲取數(shù)據(jù)并生成折線圖
這篇文章主要介紹了微信小程序使用echarts獲取數(shù)據(jù)并生成折線圖,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-10-10