實例代碼詳解javascript實現(xiàn)窗口抖動及qq窗口抖動
窗口抖動效果在很多地方都有應用,例如網(wǎng)易的登陸窗口就有這樣的效果,當?shù)顷懯〉臅r候就會出現(xiàn)抖動效果,這不但有動感,而且讓人感覺新穎,下面是一段這樣的代碼實例,和大家分享一下。
代碼如下:
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"/> <meta name="author" content="http://www.softwhy.com/" /> <title>窗口登陸效果</title> <style type="text/css"> #win { position:relative; width:100px; height:100px; background-color:#666; } </style> <script type="text/javascript"> var a=['top','left']; var b=0; var u; function fudu() { win.style[a[b%2]]=(b++)%4<2?"0px":"4px"; if(b>15) { clearInterval(u); b=0 } } function zd() { clearInterval(u); u=setInterval(fudu,32) } window.onload=function() { var bt=document.getElementById("bt"); var win=document.getElementById("win"); bt.onclick=zd; } </script> </head> <body > <button id="bt">點擊振動</button> <div id="win"></div> </body> </html>
以上代碼中,當點擊按鈕的時候,div會出現(xiàn)抖動效果,當然此效果比較簡單,這里僅僅是演示之用,在實際應用中可以自行擴展,下面簡單介紹一下實現(xiàn)過程。
一.實現(xiàn)原理:
代碼簡單,原理也是非常簡單。div是采用相對定位,當點擊按鈕的時候,就會通過定時器函數(shù)setInterval()不斷調(diào)用fudu()函數(shù),此函數(shù)可以通過取模的方式來不斷的設(shè)置left或者top的屬性值,也就是不斷隨機的調(diào)整div的位置,這樣就實現(xiàn)了抖動效果,當b的值大于15的時候,停止抖動。
二.代碼注釋:
1.var a=['top','left'],聲明一個數(shù)組,里面存儲有top和left字符串。
2.var b=0,聲明一個變量b并賦值為0。
3.var u,聲明一個變量,作為定時器函數(shù)setInterval()的返回值。
4.function fudu(){},聲明一個函數(shù)。
5.win.style[a[b%2]]=(b++)%4<2?"0px":"4px",此段代碼是核心部分,b%2取模運算的值為0或1,這樣就成為數(shù)組a的索引值用于獲取數(shù)組中的值。style[a[b%]這種形式和style.top這種形式的效果是一樣的。]]=(b++)%4<2?"0px":"4px",這樣通過取模判斷值是否小于2,來對div的top和left屬性賦值。
6.if(b>15) {clearInterval(u); b=0} ,如果b的值大于15,那么就停止抖動,并將b的值重置為0。
7.function zd(){},聲明一個函數(shù)。
8.clearInterval(u),停止定時器函數(shù)的運行,這句代碼是為了防止連續(xù)點擊按鈕出現(xiàn)抖動可能不停止問題,因為兩個抖動互相影響。
9.u=setInterval(fudu,30),使用定時器函數(shù)不斷調(diào)用fudu函數(shù)。
10.window.onload=function(){},當文檔內(nèi)容完全加載完畢再去執(zhí)行函數(shù)中的代碼。
11.var bt=document.getElementById("bt"),獲取按鈕對象。
12.var win=document.getElementById("win"),獲取div對象。
13.bt.onclick=zd,為按鈕注冊事件處理函數(shù)。
下面給大家介紹仿QQ窗口抖動的JavaScript代碼
很不借的抖動特效,仿QQ聊天窗口的抖動效果,這里是用JavaScript代碼實現(xiàn),在配上這個假聊天窗口,沒想到竟然和QQ的抖動效果還真相似,挺逗人。
<title>仿QQ窗口抖動</title> <img id="win" style='position:relative' src="/jscss/demoimg/qqwinows.jpg"> <br /><br /> <button onclick="zd()">讓我抖一下!</button> <script > function zd(u){ var a=['top','left'],b=0; u=setInterval(function(){ document.getElementById('win').style[a[b%2]]=(b++)%4<2?0:4; if(b>15){clearInterval(u);b=0} },32) } </script>
通過以上實例代碼給大家介紹javascript實現(xiàn)窗口抖動及qq窗口抖動的相關(guān)內(nèi)容,希望本段代碼能夠幫助到大家。
相關(guān)文章
JavaScript二維數(shù)組實現(xiàn)的省市聯(lián)動菜單
這篇文章主要介紹了使用二維數(shù)組實現(xiàn)的省市聯(lián)動菜單,通過二維數(shù)組存儲城市列表項,需要的朋友可以參考下2014-05-05JavaScript必知必會(二) null 和undefined
這篇文章主要介紹了JavaScript必知必會(二) null 和undefined的相關(guān)資料,非常不錯具有參考借鑒價值,需要的朋友可以參考下2016-06-06JS表格組件神器bootstrap table詳解(強化版)
這篇文章主要以實例的方式為大家再次介紹了JS表格組件神器bootstrap table,bootstrap table界面采用扁平化的風格,用戶體驗比較好,更好兼容各種客戶端,需要了解更多bootstrap table的朋友可以參考下2016-05-05微信小程序?qū)崿F(xiàn)點擊按鈕移動view標簽的位置功能示例【附demo源碼下載】
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)點擊按鈕移動view標簽的位置功能,涉及微信小程序事件綁定與this.setData動態(tài)修改data數(shù)值進而改變view標簽樣式的相關(guān)操作技巧,需要的朋友可以參考下2017-12-12js與jQuery實現(xiàn)的用戶注冊協(xié)議倒計時功能實例【三種方法】
這篇文章主要介紹了js與jQuery實現(xiàn)的用戶注冊協(xié)議倒計時功能,結(jié)合實例形式分析了三種倒計時功能的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2017-11-11關(guān)于Javascript中defer和async的區(qū)別總結(jié)
相信看過javascript高級程序設(shè)計的人,在javascript高級程序設(shè)計里,應該看到了介紹了有關(guān)defer和async的區(qū)別,可是比較淺顯,而且也說得不是很清楚。下面我們來通過這篇文章來詳細了解下dfer和async的區(qū)別。2016-09-09