今天突發(fā)奇想,js能不能通過字符串和定時(shí)器來實(shí)現(xiàn)游戲中的對(duì)話效果呢。試了一下,還真挺好玩的。
上效果圖:
本節(jié)涉及的知識(shí)點(diǎn):
- 字符串的charAt方法
- js定時(shí)器setInterval(輪詢)
1. charAt方法
js的charAt方法是用來獲取字符串中的某一個(gè)字符的钻蔑,它是屬于string的一個(gè)方法。
比如:
var str = 'ABCDEFG';
var a = str.charAt(6);//取下標(biāo)為6的字符
alert(a);
2. setInterval定時(shí)器
具體用法如下:
setInterval(function(){
},1000);
第一個(gè)參數(shù)是一個(gè)回調(diào)函數(shù)奸鸯,代表了你要做的事情咪笑。
第二個(gè)參數(shù)是延時(shí)的時(shí)間,代表了每隔多長時(shí)間就觸發(fā)一次函數(shù)里邊的內(nèi)容娄涩。
注意:js是單線程的窗怒,它沒有像JAVA語言那樣的sleep方法。在js中任何的動(dòng)畫效果蓄拣,基本上都要通過 setInterval 或者 setTimeout來實(shí)現(xiàn)扬虚。
3. 繪圖
css:
* {margin:0;padding:0}
body {
background: url(bg.jpg) no-repeat;
background-size: 100%;
}
.dialog {
width:100%;
height:100px;
background:rgba(136,180,251,0.5);
position:absolute;
bottom: 0;
}
.dialog .pic {
width:60px;
height:60px;
background:url(1.png) no-repeat;
background-size: 100%;
display:inline-block;
position: absolute;
top:16px;
left:16px;
border-radius: 5px;
}
.dialog .innerBox{
width:90%;
height:80px;
border:2px solid #dcc0a5;
opacity: 0.8;
left:85px;
top:10px;
position: absolute;
border-radius: 5px;
font-size: 20px;
font-family: 微軟雅黑;
color:#fff;
text-shadow: 1px -1px 1px #333;
word-wrap:break-word;
padding:2px;
}
html:
<div class='dialog'>
<span class='pic'></span>
<div class='innerBox'></div>
</div>
效果圖:
圖片素材我是隨便去網(wǎng)上截取的。
4. js實(shí)現(xiàn)打印機(jī)效果
我們可以通過定時(shí)器來實(shí)現(xiàn)一個(gè)延時(shí)球恤,比如現(xiàn)在我有一個(gè)字符串:
var str = "Hello World辜昵!"
在body區(qū)域,我有一個(gè)div用來輸出文字咽斧。
<body>
<div id='text'></div>
</body>
如果你用for循環(huán)堪置,雖然能依次打印,但這樣是看不到動(dòng)畫效果的张惹。
var str = "Hello World晋柱!"
var text = document.getElementById('text');
for(var i = 0; i < str.length; i++){
text.innerHTML += str.charAt(i);
}
在不知道setInterval之前,我曾經(jīng)天真的以為诵叁,可以使用單片機(jī)中C語言的軟件延時(shí)方法,也就是在for循環(huán)里面增加一個(gè)無意義的循環(huán)操作來消磨cpu的時(shí)間钦椭,以達(dá)到延時(shí)的目的拧额。
后來我發(fā)現(xiàn)在js中根本不是那么回事碑诉,其實(shí),js的for循環(huán)是一口氣執(zhí)行好了侥锦,再展示給你的进栽。
所以,如果你想通過for循環(huán)來達(dá)到延時(shí)的目的應(yīng)該是不可能的恭垦。
好在js給我們提供了一個(gè)setInterval的輪詢方法快毛,我們可以通過這個(gè)方法來達(dá)到文字的動(dòng)畫效果。
代碼如下:
window.onload = function(){
var innerBox = document.getElementsByClassName('innerBox')[0];
var text = 'JavaScript一種直譯式腳本語言番挺,是一種動(dòng)態(tài)類型唠帝、弱類型、基于原型的語言玄柏,內(nèi)置支持類型襟衰。它的解釋器被稱為JavaScript引擎,為瀏覽器的一部分粪摘,廣泛用于客戶端的腳本語言瀑晒,最早是在HTML(標(biāo)準(zhǔn)通用標(biāo)記語言下的一個(gè)應(yīng)用)網(wǎng)頁上使用,用來給HTML網(wǎng)頁增加動(dòng)態(tài)功能徘意。天空苔悦,你也要好好學(xué)習(xí)呀!';
var len = text.length;
var timer = null;
var index = 0;
timer = setInterval(function(){
if(index == len){
clearInterval(timer);
}
innerBox.innerHTML += text.charAt(index++);
},50);
}
思路:
1.新建一個(gè)需要?jiǎng)赢嬚故镜奈谋?br>
2.記錄下當(dāng)前遍歷的字符位置
3.記錄文本的總長度
4.新建一個(gè)定時(shí)器timer
5.50ms輪詢椎咧,每次輪詢都取文本的下一個(gè)字符玖详,添加到innerBox。
6.當(dāng)最后一個(gè)字符也遍歷完了邑退,繼續(xù)進(jìn)入輪詢的時(shí)候竹宋,就清除定時(shí)器。
效果(截圖原因看起來有點(diǎn)卡頓地技,其實(shí)是非常流暢的哦):
本章結(jié)束 ...
剽悍一小兔蜈七,電氣自動(dòng)化畢業(yè)。
參加工作后對(duì)計(jì)算機(jī)感興趣莫矗,深知初學(xué)編程之艱辛飒硅。
希望將自己所學(xué)記錄下來,給初學(xué)者一點(diǎn)幫助作谚。
免責(zé)聲明: 博客中所有的圖片素材均來自百度搜索三娩,僅供學(xué)習(xí)交流,如有問題請(qǐng)聯(lián)系我妹懒,侵立刪雀监,謝謝。