使用原生JS實現(xiàn)移動端圖片輪播效果(二)

在上篇文章中,使用改變left的值實現(xiàn)輪播效果,在PC端上因為要兼容舊版瀏覽器,所以都采用這種做法西土。但是在移動端上會使瀏覽器造成極大的性能開銷,在一些老機型中會出現(xiàn)明顯的卡頓鞍盗,用戶體驗不好需了,所以在這篇文章中將使用translate實現(xiàn)輪播。translate樣式的變化會造成重繪橡疼,但是并不會進行CSS樣式的重新計算和布局援所,其性能要明顯優(yōu)于left。

在整體結(jié)構(gòu)不變的前提下欣除,只是更改了其JS文件就能實現(xiàn)相關(guān)效果住拭,為了能夠更好的更改和讀取其translateX的值,所以寫了一個相關(guān)的函數(shù)。

// 只傳入兩個實參則為獲取滔岳,傳入三個實參為設(shè)置參數(shù)值杠娱,當然為了簡單點,所以只加入了translateX這一單一屬性谱煤,用戶可以自行對該函數(shù)進行改造摊求,
//可以適當?shù)募尤雝ranslateY,scaleX,scaleY等值。
    function cssTransform(ele,attr,val){
        if(!ele.transform){
            ele.transform = {};
        };
//當傳入值時對屬性進行設(shè)置刘离。
        if(arguments.length>2){
            ele.transform[attr] = val;
            var sval = "";
            for(var s in ele.transform){
                if(s == "translateX"){
                    sval += s + "("+ele.transform[s] +"px)";
                }
                ele.style.WebkitTransform = ele.style.transform = sval;
            }
            
        }else{
            val = ele.transform[attr];
            if(typeof val=="undefined"){
                if(attr=="translateX"){
                    val = 0;
                }
            };
            console.log(val);
            return val;
        }
    }

在代碼中室叉,有幾個重要的點,掌握其原理之后硫惕,移動端輪播就基本可以了茧痕。

1.在頁面剛加載時,設(shè)置盒子的translateX為0恼除,并取消定時器踪旷。
2.當手指按下的時候,取消其transition豁辉,判斷當前屬于第幾張圖片令野,當為第零張圖片的時候,將盒子迅速拉至復制出來的圖片的第一張徽级,當圖片在最后一張的時候气破,將盒子迅速拉至未復制的圖片的最后一張。
3.當手指滑屏時灰追,改變其box的tranflateX.
4.當手指抬起時堵幽,得到處于第幾張照片,然后將其滑入弹澎,并開啟定時器。

var wrap = document.querySelector(".wrap");
var box = document.querySelector(".box");
box.innerHTML+=box.innerHTML;
var aLi = document.querySelectorAll(".box li");
var aNav = document.querySelectorAll("nav span");
var aHeight = aLi[0].offsetHeight;
var aWidth = wrap.offsetWidth;
wrap.style.height = aHeight + 'px';
box.style.width = aLi.length * 100 + "%";
for(var i=0;i<aLi.length;i++){
    aLi[i].style.width = 1/aLi.length * 100 + "%";
}
var startPoint = 0;
var startEle = 0;
var now = 0;
var timer = 0;
cssTransform(box,"translateX",0);
auto();
wrap.addEventListener("touchstart",function(e){
    clearInterval(timer);
    box.style.transition = "none";
    var moveX = cssTransform(box,"translateX");
    now = Math.round(-moveX/aWidth);
    if(now==0){
        now = aNav.length;
    }else if(now==aLi.length-1){
        now = aNav.length-1;
    }
    cssTransform(box,"translateX",-now*aWidth);
    startPoint = e.changedTouches[0].pageX;
    startEle = cssTransform(box,"translateX");
});
wrap.addEventListener("touchmove",function(e){
    var endPoint = e.changedTouches[0].pageX;
    var disX = endPoint - startPoint;
    cssTransform(box,"translateX",disX+startEle);
});
wrap.addEventListener("touchend",function(e){
    var moveX = cssTransform(box,"translateX");
    now = Math.round(-moveX/aWidth);
    tab();auto();
    
});
function auto(){
    clearInterval(timer);
    timer = setInterval(function(){
        if(now == aLi.length-1){
            now = aNav.length - 1;
        }
        box.style.transition = "none";
        cssTransform(box,"translateX",-now*aWidth);
        setTimeout(function(){
            now++;
            tab();
        },30);
    },2000);
};
function tab(){
    box.style.transition = ".5s";
    cssTransform(box,"translateX",-now*aWidth);
    for(var i=0;i<aNav.length;i++){
        aNav[i].className = "";
    };
    aNav[now%aNav.length].className = "active";
}

以上代碼都放在:https://github.com/waterwong/swiper

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末努咐,一起剝皮案震驚了整個濱河市苦蒿,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌渗稍,老刑警劉巖佩迟,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異竿屹,居然都是意外死亡报强,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門拱燃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來秉溉,“玉大人,你說我怎么就攤上這事≌偎唬” “怎么了父晶?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長弄跌。 經(jīng)常有香客問我甲喝,道長,這世上最難降的妖魔是什么铛只? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任埠胖,我火速辦了婚禮,結(jié)果婚禮上淳玩,老公的妹妹穿的比我還像新娘押袍。我一直安慰自己,他們只是感情好凯肋,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布谊惭。 她就那樣靜靜地躺著,像睡著了一般侮东。 火紅的嫁衣襯著肌膚如雪圈盔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天悄雅,我揣著相機與錄音驱敲,去河邊找鬼。 笑死宽闲,一個胖子當著我的面吹牛众眨,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播容诬,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼娩梨,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了览徒?” 一聲冷哼從身側(cè)響起狈定,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎习蓬,沒想到半個月后纽什,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡躲叼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年芦缰,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片枫慷。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡让蕾,死狀恐怖浪规,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情涕俗,我是刑警寧澤罗丰,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布衙荐,位于F島的核電站彤断,受9級特大地震影響唧龄,放射性物質(zhì)發(fā)生泄漏耀石。R本人自食惡果不足惜甚纲,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一沧踏、第九天 我趴在偏房一處隱蔽的房頂上張望喉镰。 院中可真熱鬧内贮,春花似錦栖疑、人聲如沸讨永。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽卿闹。三九已至,卻和暖如春萝快,著一層夾襖步出監(jiān)牢的瞬間锻霎,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工揪漩, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留旋恼,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓奄容,卻偏偏與公主長得像冰更,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子昂勒,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容