這篇文章主要幫助大家簡單實現JavaScript彈幕效果
不知大家有沒有感受到,彈幕又是另一齣好戲! !
不過我個人還是比較排斥看電視的時候被出來的彈幕打擾。今天我們來寫一個簡單的彈幕。簡單到什麼程度呢?看下效果:
由圖可以看出,我們的呆毛html結構確實是非常簡單啦。
就是由一個p、一個input框另加一個button組成。
<p id="box" class="box"></p> <input type="text" id="txt" /> <button onclick="send()">提交内容</button>
先po上js程式碼:
function $(str) { return document.getElementById(str); } function send() { var word = $('txt').value; var span = document.createElement('span'); var top = parseInt(Math.random() * 500) - 20; var color1 = parseInt(Math.random() * 256); var color2 = parseInt(Math.random() * 256); var color3 = parseInt(Math.random() * 256); var color = "rgb(" + color1 + "," + color2 + "," + color3 + ")"; top = top < 0 ? 0 : top; span.style.position = 'absolute'; span.style.top = top + "px"; span.style.color = color; span.style.left = '500px'; span.style.whiteSpace = 'nowrap'; var nub = (Math.random() * 10) + 1; span.setAttribute('speed', nub); span.speed = nub; span.innerHTML = word; $('box').appendChild(span); $('txt').value = ""; } setInterval(move, 200); function move() { var spanArray = $('box').children; for (var i = 0; i < spanArray.length; i++) { spanArray[i].style.left = parseInt(spanArray[i].style.left) - spanArray[i].speed + 'px'; } }
原理簡單說下:
第一步,我們要拿到input框裡面的內容,var word = $('txt').value;
第二步,我們就要把這個內容想辦法地塞到要滾動顯示的p裡面去了,原則有三:①顏色隨機②高度隨機③與左邊框的距離實時變化;
第三步,把這個內容追加到p裡 $('box').appendChild (span);
由上述步驟原理可以看出,第二步是最關鍵的一步,
#實作第一個原則:
var color1 = parseInt(Math.random() * 256); var color2 = parseInt(Math.random() * 256); var color3 = parseInt(Math.random() * 256); var color = "rgb(" + color1 + "," + color2 + "," + color3 + ")"; span.style.color = color;
#小擴充:
RGB(R,G,B);
R:
紅色值。正整數 | 百分數
G:
綠色值。正整數 | 百分數
B:
藍色值。正整數 | 百分數
這樣就應該是很容易理解了。
實作第二個原則:
var top = parseInt(Math.random() * 500) - 20; top = top < 0 ? 0 : top; span.style.top = top + "px";
實作第三個原則:
span.style.left = '500px'; setInterval(move, 200); function move() { var spanArray = $('box').children; for (var i = 0; i < spanArray.length; i++) { spanArray[i].style.left = parseInt(spanArray[i].style.left) - spanArray[i].speed + 'px'; } }
就是利用了定時器的原理,讓left的值即時變化。
講到這裡,就應該很清晰明了吧。
以上是JavaScript實作簡單的彈幕效果實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!