jQuery實現(xiàn)圣誕節(jié)禮物傳送(花式輪播)
大致介紹
下午看到了一個送圣誕禮物的小動畫,正好要快到圣誕節(jié)了,就動手模仿并改進(jìn)了一些小問題
原地址:花式輪播----圣誕禮物傳送
思路:動畫中一共有五個禮物,他們平均分布在屏幕中,設(shè)置最外邊的兩個禮物旋轉(zhuǎn)一定的角度并隱藏,動畫開始,每個禮物向右移動一定的位置,然后再把第五個禮物添加到第一個禮物之前,這樣這五個禮物就重新排列了,在寫jQ時只管禮物位置的變化就行了,因為禮物的旋轉(zhuǎn)和隱藏在樣式中都已經(jīng)設(shè)置好了,某個禮物如果成為第一個禮物就會自動隱藏旋轉(zhuǎn)
基本結(jié)構(gòu)
代碼:
<div class="cr"> <div class="cr-l"><img src="img/fatherCh.png" alt=""/></div> <div class="cr-icon"> <div id="cr-icon"> <img style="left:5%" src="img/gift2.png" alt=""/> <img style="left:25%" src="img/gift2.png" alt=""/> <img style="left:45%" src="img/gift2.png" alt=""/> <img style="left:65%" src="img/gift2.png" alt=""/> <img style="left:85%" src="img/gift2.png" alt=""/> </div> </div> <div class="cr-r"><img src="img/family.png" alt=""/></div> </div>
樣式
在css中用到了:first 和 :last 屬性,這兩個屬性是動態(tài)的,如果文檔的結(jié)構(gòu)變了,這兩個屬性的值也會相應(yīng)的改變,這樣我們就不必再麻煩的判斷哪個元素是最后一個元素(第一個元素),直接用這兩個屬性就會自動選擇第一個元素和最后一個元素
html, body {
height: 100%;
margin: 0;
padding: 0;
}
.cr{
width: 100%;
position: relative;
background: url("../img/bg.png") no-repeat 0 0;
-webkit-background-size: 100% 100%;
background-size: 100% 100%;
overflow: hidden;
}
.cr-l,.cr-r{
position: absolute;
bottom:10%;
width: 20.8%;
height: 70%;
z-index:100;
}
.cr-l img,.cr-r img{
width: 100%;
position: absolute;
top:50%;
}
.cr-l{
left: 0;
}
.cr-r{
right:0;
}
.cr-icon{
bottom: 15%;
left:0;
position: absolute;
z-index: 1000;
width: 100%;
height: 70%;
text-align: center;
}
.cr-icon img{
margin-right: 25px;
width: 10%;
vertical-align: top;
position: absolute;
bottom: 0;
opacity: 1;
transform:rotate(0deg);
transition: all 1s;
}
.cr-icon img:first-child{
transform:rotate(-90deg);
-webkit-transform:rotate(-90deg);
opacity: 0;
width: 0;
}
.cr-icon img:last-child{
transform:rotate(90deg);
-webkit-transform:rotate(90deg);
opacity: 0;
width: 0;
}
jQuery代碼
在源碼中,作者將這個五個禮物的初始位置寫在了HTML結(jié)構(gòu)中,我覺得不太好就在jQuery的代碼中實現(xiàn)了,代碼沒有什么難的,就是對思路的實現(xiàn)
$(function() {
// 點擊禮物圖片,切換圖片
$('#cr-icon img').click(function(){
if($(this).attr('src') == 'img/gift2.png'){
$(this).attr('src','img/gift.png');
}else{
$(this).attr('src','img/gift2.png');
}
});
var timer = null;
var oImg = $('#cr-icon img');
var end = document.body.clientWidth;
var height = document.body.scrollHeight;
// 設(shè)置高
$(".cr").css("height",height);
// 設(shè)置圖片的初始位置
for(var i=0;i<oImg.length;i++){
$(oImg[i]).css('left', 5+i*20+'%');
}
// 圖片輪換函數(shù)
function scrollLogo(){
oImg.each(function(){
var left = parseInt($(this).css('left'));
left += end * 0.2;
$(this).css('left',left);
});
$('#cr-icon img:last').insertBefore('#cr-icon img:first').css('left',end * 0.05);
}
scrollLogo();
// 定時器,開始輪換
timer = setInterval(scrollLogo,1800);
// 鼠標(biāo)移入清楚輪換
oImg.mouseover(function(){
clearInterval(timer);
});
// 鼠標(biāo)移出開始輪換
oImg.mouseleave(function() {
timer = setInterval(scrollLogo,1800);
});
});
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
jQuery插件echarts實現(xiàn)的單折線圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件echarts實現(xiàn)的單折線圖效果,結(jié)合完整實例形式分析了echarts插件繪制簡單折線圖的操作步驟與相關(guān)實現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
jquery和雅虎的yql服務(wù)實現(xiàn)天氣預(yù)報服務(wù)示例
本文介紹一個利用Jquery和雅虎的YQL服務(wù)實現(xiàn)天氣預(yù)報功能,需要的朋友可以參考下2014-02-02
一個可以增加和刪除行的table并可編輯表格中內(nèi)容
本例要實現(xiàn)的是一個可以增加和刪除行的table并可編輯表格中內(nèi)容,適合新手朋友2014-06-06
jQuery插件HighCharts繪制的基本折線圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件HighCharts繪制的基本折線圖效果,結(jié)合實例形式分析了jQuery基于HighCharts插件繪制圖形的具體實現(xiàn)步驟與相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03

