原生JS實(shí)現(xiàn)風(fēng)箱式demo,并封裝了一個(gè)運(yùn)動(dòng)框架(實(shí)例代碼)
聲明,該DEMO依托于某個(gè)培訓(xùn)機(jī)構(gòu)中,非常感謝這個(gè)培訓(xùn)結(jié)構(gòu)。話不多說,現(xiàn)在開始改demo的制作。
首先,在前端的學(xué)習(xí)過程中,輪播圖是我們一定要學(xué)習(xí)的,所以為了更加高效的實(shí)現(xiàn)各種輪播圖,封裝了一個(gè)運(yùn)動(dòng)的框架。
function getStyle(obj,attr) {
if(obj.currentStyle){
return obj.currentStyle[attr];//為了獲取IE下的屬性值
}else{
return window.getComputedStyle(obj,null)[attr];//為了獲取W3C瀏覽器下的屬性值
}
}
function animate(obj,json){
clearInterval(obj.timer);
obj.timer = setInterval(function () {
var flag = true;
var current = 0;
for(var attr in json){
if(attr == 'opacity'){
current = parseInt(getStyle(obj,attr)*100);
}else{
current = parseInt(getStyle(obj,attr));
};
var step = (json[attr] - current) / 10;
step = step > 0 ? Math.ceil(step) : Math.floor(step);
//先判斷屬性是否為透明度
if(attr == 'opacity'){
//首先判斷瀏覽器是否支持opacity
if('opacity' in obj.style){
obj.style.opacity = (current + step) / 100;
}else{
obj.style.filter = 'alpha(opacity = ' + (current + step) + ')';
}
//再判斷屬性是否為z-index
}else if(attr == 'zIndex'){
obj.style.zIndex = json[attr];
//最后再判斷
}else{
obj.style[attr] = current + step + 'px';
}
if(current != json[attr]){
flag = false;
}
}
if(flag){
clearInterval(obj.timer);
}
},5);
}
在該框架中兼容了不同的瀏覽器,并且允許傳入opacity和z-index這樣的屬性,當(dāng)然,像width,height,left,right這樣常見的屬性是必不可少的。利用該框架,可以實(shí)現(xiàn)非常棒的效果。所以現(xiàn)在開始正式做該DEMO。
首先是index.html的制作。
<div id="box">
<ul>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</div>
index.html的制作非常的簡單,我們會(huì)將圖片作為li的背景圖片在javascript中進(jìn)行插入。之后,我們進(jìn)行CSS樣式的調(diào)節(jié)。
*{
margin:0px;
padding:0px;
}
#box{
width:1300px;
height:400px;
margin:100px auto;
overflow: hidden;
}
#box ul{
height:400px;
width:1300px;
}
#box ul li{
width:240px;
height:400px;
float:left;
overflow: hidden;
}
javascript的代碼如下:
window.onload = function () {
var box = document.getElementById('box');
var aLi = box.children[0].children;
for(var i=0;i<aLi.length;i++){
aLi[i].style.backgroundImage = 'url(' + 'images/' + (i + 1) + '.jpg';
aLi[i].onmouseover = function(){
for(var i=0;i<aLi.length;i++){
animate(aLi[i],{width:100});
}
animate(this,{width:800});
};
aLi[i].onmouseout = function(){
for(var i=0;i<aLi.length;i++){
animate(aLi[i],{width:240});
}
}
}
}
這樣使用原生JS實(shí)現(xiàn)的風(fēng)箱效果demo就實(shí)現(xiàn)了,當(dāng)然,還可以利用封裝好的animate框架實(shí)現(xiàn)類似網(wǎng)易的輪播圖效果。
以上這篇原生JS實(shí)現(xiàn)風(fēng)箱式demo,并封裝了一個(gè)運(yùn)動(dòng)框架(實(shí)例代碼)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- JS實(shí)現(xiàn)運(yùn)動(dòng)緩沖效果的封裝函數(shù)示例
- JS實(shí)現(xiàn)勻速與減速緩慢運(yùn)動(dòng)的動(dòng)畫效果封裝示例
- 原生JS實(shí)現(xiàn)圖片無縫滾動(dòng)方法(附帶封裝的運(yùn)動(dòng)框架)
- 原生JS封裝animate運(yùn)動(dòng)框架的實(shí)例
- 原生js封裝運(yùn)動(dòng)框架的示例講解
- JS實(shí)現(xiàn)勻速運(yùn)動(dòng)的代碼實(shí)例
- 使用JavaScript 實(shí)現(xiàn)對(duì)象 勻速/變速運(yùn)動(dòng)的方法
- JavaScript中的勻速運(yùn)動(dòng)和變速(緩沖)運(yùn)動(dòng)詳細(xì)介紹
- 原生javascript實(shí)現(xiàn)勻速運(yùn)動(dòng)動(dòng)畫效果
- 淺談Javascript中勻速運(yùn)動(dòng)的停止條件
- js指定步長實(shí)現(xiàn)單方向勻速運(yùn)動(dòng)
- 原生javascript運(yùn)動(dòng)函數(shù)的封裝示例【勻速、拋物線、多屬性的運(yùn)動(dòng)等】
相關(guān)文章
JS中的算法與數(shù)據(jù)結(jié)構(gòu)之集合(Set)實(shí)例詳解
這篇文章主要介紹了JS中的算法與數(shù)據(jù)結(jié)構(gòu)之集合(Set),結(jié)合實(shí)例形式詳細(xì)分析了javascript中集合的概念、原理、定義及相關(guān)操作技巧,需要的朋友可以參考下2019-08-08
js 實(shí)現(xiàn)watch監(jiān)聽數(shù)據(jù)變化的代碼
這篇文章主要介紹了js 實(shí)現(xiàn)watch監(jiān)聽數(shù)據(jù)變化的代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10
JS 實(shí)現(xiàn)雙色表格實(shí)現(xiàn)代碼
通過為<tr>元素添加屬性或類型選擇器,再通過CSS設(shè)置可以實(shí)現(xiàn)雙色表格,但如果表格很長,逐個(gè)元素添加可真麻煩。而且這樣的代碼維護(hù)起來不容易。所以比較好的方式是用JS實(shí)現(xiàn)。2009-11-11
使用Three.js實(shí)現(xiàn)太陽系八大行星的自轉(zhuǎn)公轉(zhuǎn)示例代碼
這篇文章主要給大家介紹了關(guān)于如何使用Three.js實(shí)現(xiàn)太陽系八大行星的自轉(zhuǎn)公轉(zhuǎn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Three.js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
使用forEach和ES6實(shí)現(xiàn)tab切換的示例代碼
tab切換在很多菜單欄中都可以用到,本文主要介紹了使用forEach和ES6實(shí)現(xiàn)tab切換的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
Javascript執(zhí)行流程細(xì)節(jié)原理解析
這篇文章主要介紹了Javascript執(zhí)行流程細(xì)節(jié)解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05

