這篇文章主要介紹jQuery實(shí)現(xiàn)雪花飄落效果的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
目前創(chuàng)新互聯(lián)建站已為上千多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、鄒城網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
示例:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>雪花飄落</title> </head> <style type="text/css"> body{background: black;height: 100%;overflow: hidden;} .xh{cursor: pointer;} </style> <body> <div class="bk"> </div> </body> <script src="jquery-1.8.3.min.js"></script> <script type="text/javascript"> var minSize = 5; //最小字體 var maxSize = 50;//最大字體 var newOne = 200; //生成雪花間隔 var flakColor = "#fff"; //雪花顏色 var flak = $("<div class='xh'></div>").css({position:"absolute","top":"0px"}).html("?");//定義一個(gè)雪花 var dhight = $(window).height(); //定義視圖高度 var dw =$(window).width(); //定義視圖寬度 setInterval(function(){ var sizeflak = minSize+Math.random()*maxSize; //產(chǎn)生大小不等的雪花 var startLeft = Math.random()*dw; //雪花生成是隨機(jī)的left值 var startopcity = 0.7+Math.random()*0.3; //隨機(jī)透明度 var endpositionTop= dhight-100; //雪花停止top的位置 var endLeft= Math.random()*dw; //雪花停止的left位置 var durationfull = 5000+Math.random()*3000; //雪花飄落速度不同 flak.clone().appendTo($("body")).css({ "left":startLeft , "opacity":startopcity, "font-size":sizeflak, "color":flakColor }).animate({ "top":endpositionTop, "left":endLeft, "apacity":0.1 },durationfull,function(){ $(this).remove() }); },newOne); </script> </html>
上面是代碼,是不是很簡(jiǎn)單,你們?cè)撜f(shuō)了能做到想要的效果嗎?下面就讓你們看看效果
上面就是效果了,可以把雪花換成錢(qián)或者其他東西,背景也可以改變一下,然后加個(gè)圣誕老人圖片,以及其他的,這樣就是一個(gè)簡(jiǎn)單的圣誕頁(yè)面了,其實(shí)也是很酷的。
當(dāng)然我們也可以加點(diǎn)其他的交互效果,把圖片換成小飛機(jī),然后做個(gè)打飛機(jī)的網(wǎng)頁(yè)游戲,其實(shí)也是很簡(jiǎn)單的,只需在這個(gè)上面增加交互和一些邏輯就行了。下面我就給大家一步一步的講解一下整個(gè)程序設(shè)計(jì)的思路。
前提摘要: 我這個(gè)用了jq,當(dāng)然也可以用原生寫(xiě),只是jq比較省事,所以就用了jq。
首先引入jq: <script src="jquery-1.8.3.min.js"></script>
這個(gè)需要根據(jù)自己的真實(shí)目錄來(lái)寫(xiě),引入的時(shí)候注意兩點(diǎn):
一、記住一般引入的話最好放到整個(gè)頁(yè)面的最下面,因?yàn)樵陧?yè)面加載的時(shí)候是從上往下加載的,如果jq引入的時(shí)候在樣式的上面就會(huì)使得頁(yè)面加載速度慢,影響用戶體驗(yàn),所以放在下面就會(huì)使得先加載樣式和圖片,有利于用戶體驗(yàn)。
二、引入的時(shí)候不要放到依賴jq代碼的下面,因?yàn)轫?yè)面加載從上往下加載,要是放到下面的話就會(huì)使得依賴的代碼找不到j(luò)q變量和方法,就會(huì)報(bào)錯(cuò)。
二、在寫(xiě)之前先想一下需要的變量,然后定義一下變量:
我們做的是雪花飄落,所以我用*好來(lái)代替雪花,所以我們就要知道定義一個(gè)雪花,var flak = $("<div class='xh'></div>").css({position:"absolute","top":"0px"}).html("?");
//定義一個(gè)雪花 ,然后我們要想一下雪花的屬性,知道雪花的幾個(gè)屬性。
1、我們知道下雪的時(shí)候雪花的大小是不一樣的,所以我們?cè)诙x雪花大小的時(shí)候要用個(gè)最大雪花和最小雪花的尺寸,在js 指定間隔執(zhí)行函數(shù)setinterval中我們用了隨機(jī)數(shù),使得雪花隨機(jī)生成在最大的到最小的之間的尺寸:
var sizeflak = minSize+Math.random()*(maxSize-minSize);
//產(chǎn)生大小不等的雪花
2、定義一下間隔執(zhí)行函數(shù)的間隔,這個(gè)也可以不定義,直接寫(xiě)上也行
3、定義一下雪花的自身固定屬性顏色,定義一下視圖的寬度。
三、根據(jù)之前定義變量引入到間隔循環(huán)函數(shù)內(nèi):
到了這一步就簡(jiǎn)單的多了,因?yàn)檫@個(gè)函數(shù)是每隔多少秒執(zhí)行一次,所以我們只需要把之前定義的東西都取最大值和最小值之間就行了。然后將之前定義的雪花克隆一下,這里講一下jq的克隆和js的克隆
jq的克隆是節(jié)點(diǎn)直接.clone()
,是封裝好的js克隆方法。js就是直接節(jié)點(diǎn).cloneNode(true)
,只需要知道就行了,這樣就不會(huì)過(guò)于依賴jq庫(kù)了。
最后一步 :將克隆好的節(jié)點(diǎn)放入到我們的父節(jié)點(diǎn)中,也就是視圖中,我們這里的視圖是body,所以直接appendto(body)
,然后jq有個(gè)動(dòng)畫(huà)api,我們直接用這個(gè)api使得整個(gè)雪花從克隆出來(lái)到運(yùn)動(dòng)起來(lái),然后運(yùn)動(dòng)完
后將克隆出來(lái)的雪花remove掉,這樣就實(shí)現(xiàn)了整個(gè)雪花飄落的效果。
總結(jié) :這個(gè)頁(yè)面的交互不多,但是也包含了一些知識(shí)點(diǎn),總結(jié)一下用到了那些關(guān)鍵技術(shù)。
1、雪花隨機(jī)飄落和隨機(jī)大小 Math.random()產(chǎn)生0-1的隨機(jī)數(shù)
2、間隔執(zhí)行函數(shù)的運(yùn)用 setInterval(function(){},時(shí)間間隔)
3、jq的動(dòng)畫(huà)函數(shù) animate
4、克隆和刪除節(jié)點(diǎn) clone() remove()
以上是“jQuery實(shí)現(xiàn)雪花飄落效果的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
當(dāng)前標(biāo)題:jQuery實(shí)現(xiàn)雪花飄落效果的示例分析
地址分享:http://jinyejixie.com/article4/gdhoie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、靜態(tài)網(wǎng)站、服務(wù)器托管、網(wǎng)頁(yè)設(shè)計(jì)公司、小程序開(kāi)發(fā)、App設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)