ionic1開發(fā)之造一個(gè)簡單的Swiper

關(guān)于Swiper骇塘,這里就不再多說街佑。
ionic的ion-slides組件也是基于Swiper的再封裝叹括。

Swiper官網(wǎng)地址:http://idangero.us/swiper/#.Vmc1J-ODFBc
ion-slides文檔地址:https://ionicframework.com/docs/v1/api/directive/ionSlides/

Note

我們需要用到ngTouch.js來監(jiān)聽touch事件惯驼。
大家最好在項(xiàng)目中引用ngTouch.js掘殴,而不是ngTouch.min.js泡孩,因?yàn)槲覀兛赡軙?huì)在ngTouch.js里面屏蔽幾句代碼车摄。

如果你的項(xiàng)目中還沒有這個(gè)插件,也請(qǐng)自行下載之仑鸥。
下載地址:https://github.com/nglar/ngTouch


閑話不多說吮播,直接上代碼!

HTML代碼:

<div class='imc-swiper-container'>
  <div class='imc-swiper-wrapper' ng-touchend="onTouchEnd($event)" ng-touchmove="onTouchMove($event)" ng-touchstart="onTouchStart($event)">
    <div ng-repeat='slide in imcSlides' class='imc-swiper-slide'>[YOUR DOM ELEMENTS]</div>
  </div>
</div>

CSS代碼:

.imc-swiper-container {
    min-height: 120px;
    height: 100%;
    overflow: hidden;
    position: relative;
}

.imc-swiper-wrapper {
    display: flex;
    align-items: flex-start;
    height: 100%眼俊;
    transition-property: transform;
}

.imc-swiper-slider {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 120px;
    flex-shrink: 0;
}

JS代碼:

  var startX = 0;
  var startY = 0;
  var currentIndex = 0;

  var minMoveDistance = 100;
  var itemWidth = document.body.offsetWidth;

  var isUpDown;

  $scope.onTouchStart = function (event) {
    startX = event.originalEvent.changedTouches[0].pageX;
    startY = event.originalEvent.changedTouches[0].pageY;
  };

  $scope.onTouchMove = function (event) {

    var currentX = event.originalEvent.changedTouches[0].pageX;
    var currentY = event.originalEvent.changedTouches[0].pageY;

    /**
     * 本文的重中之重意狠,就是如何判斷你的操作是上下滑動(dòng)還是左右滑動(dòng)!4帧环戈!
     * 最開始,是想用滑動(dòng)的距離來判斷澎灸,
     * 當(dāng)x的變化超過某個(gè)數(shù)值的時(shí)候就表示是左右滑動(dòng)院塞;
     * 當(dāng)y的變化超過某個(gè)數(shù)值的時(shí)候就表示是上下滑動(dòng)。
     * 當(dāng)然想法是美好的性昭,但是現(xiàn)實(shí)卻是殘酷的迫悠。
     * 這樣子做了之后,發(fā)現(xiàn)上下滑動(dòng)的時(shí)候同時(shí)也能左右滑動(dòng)巩梢。允悲创泄!
     *
     * 最后,在閱讀了ion-slides組件的源碼之后括蝠,
     * 發(fā)現(xiàn)它是用滑動(dòng)的角度來判定滑動(dòng)方向的
     * touchAngle = Math.atan2(Math.abs(currentY - startY), Math.abs(currentX - startX)) * 180 / Math.PI
     * 直接copy過來鞠抑,確實(shí)好用!
     *
     * 最后的最后忌警,如果你已經(jīng)這樣做了搁拙,
     * 但是當(dāng)你手指放在這個(gè)組件上不能上下滑動(dòng)整個(gè)屏幕,
     * 那么你可能需要屏蔽掉ngTouch.js里面的// event.preventDefault();
     *
     * */
    if (typeof isUpDown === 'undefined') {
      var touchAngle = Math.atan2(Math.abs(currentY - startY), Math.abs(currentX - startX)) * 180 / Math.PI;
      isUpDown = touchAngle > 45;
    }

    if (isUpDown) {
      return;
    }

    event.preventDefault();
    event.stopPropagation();

    var offsetX = currentX - startX;
    if (Math.abs(offsetX) > itemWidth) {
      offsetX = offsetX > 0 ? itemWidth : -itemWidth;
    }
    var translateX = (-itemWidth * currentIndex) + offsetX;

     angular.element(event.currentTarget).css('transform', 'translate3d(translateX, 0px, 0px)');
     angular.element(event.currentTarget).css('transition-duration', '0ms');
  };

  $scope.onTouchEnd = function (event) {
    if (isUpDown) {
      isUpDown = undefined;
      return;
    }
    isUpDown = undefined;

    var endX = event.originalEvent.changedTouches[0].pageX;
    var offset = endX - startX;

    if (offset > minMoveDistance) {
      // touch move right
        var translateX;

        if (currentIndex === 0) {
          translateX = 0;
        } else {
          translateX = -itemWidth * (currentIndex - 1);
        }

      angular.element(event.currentTarget).css('transform', 'translate3d(translateX, 0px, 0px)');
      angular.element(childEle).css('transition-duration', '500ms');

      if (currentIndex !== 0) {
        currentIndex--;
      }
    } else if (offset < -minMoveDistance) {
      // touch move left
        var translateX;

        if (currentIndex === event.currentTarget.children.length - 1) {
          translateX = -itemWidth * currentIndex;
        } else {
          translateX = -itemWidth * (currentIndex + 1);
        }

      angular.element(event.currentTarget).css('transform', 'translate3d(translateX, 0px, 0px)');
      angular.element(event.currentTarget).css('transition-duration', '500ms');

      if (currentIndex !== event.currentTarget.children.length - 1) {
        currentIndex++;
      }

    } else {
        var translateX = -itemWidth * currentIndex;
        angular.element(event.currentTarget).css('transform', 'translate3d(translateX, 0px, 0px)');
        angular.element(event.currentTarget).css('transition-duration', '500ms');
    }
  };
}
后記

說是造一個(gè)簡單的Swiper法绵,其實(shí)就是照著ionSlides組件仿了一個(gè)粗糙的Swiper箕速。
更像是閱讀了源碼之后交的一份簡單的作業(yè)。
當(dāng)然朋譬,還有很多地方還可以做到更好更加酷炫盐茎,大家一起努力吧!

  1. slide循環(huán)
  2. 垂直方向滑動(dòng)
  3. 手指短時(shí)間的滑動(dòng)切換到下一個(gè)slide(使用時(shí)間戳計(jì)時(shí))
  4. 加載無限多的slide
  5. 更加酷炫的轉(zhuǎn)場動(dòng)畫
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末徙赢,一起剝皮案震驚了整個(gè)濱河市字柠,隨后出現(xiàn)的幾起案子探越,更是在濱河造成了極大的恐慌,老刑警劉巖窑业,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件钦幔,死亡現(xiàn)場離奇詭異,居然都是意外死亡常柄,警方通過查閱死者的電腦和手機(jī)鲤氢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來西潘,“玉大人卷玉,你說我怎么就攤上這事〗占埽” “怎么了揍庄?”我有些...
    開封第一講書人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵咆蒿,是天一觀的道長东抹。 經(jīng)常有香客問我,道長沃测,這世上最難降的妖魔是什么缭黔? 我笑而不...
    開封第一講書人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮蒂破,結(jié)果婚禮上馏谨,老公的妹妹穿的比我還像新娘。我一直安慰自己附迷,他們只是感情好惧互,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著喇伯,像睡著了一般喊儡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上稻据,一...
    開封第一講書人閱讀 49,079評(píng)論 1 285
  • 那天艾猜,我揣著相機(jī)與錄音,去河邊找鬼捻悯。 笑死匆赃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的今缚。 我是一名探鬼主播算柳,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼姓言!你這毒婦竟也來了埠居?” 一聲冷哼從身側(cè)響起查牌,我...
    開封第一講書人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎滥壕,沒想到半個(gè)月后纸颜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绎橘,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年胁孙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片称鳞。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡涮较,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出冈止,到底是詐尸還是另有隱情狂票,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布熙暴,位于F島的核電站闺属,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏周霉。R本人自食惡果不足惜掂器,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望俱箱。 院中可真熱鬧国瓮,春花似錦、人聲如沸狞谱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽跟衅。三九已至孵睬,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間与斤,已是汗流浹背肪康。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留撩穿,地道東北人磷支。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像食寡,于是被迫代替她去往敵國和親雾狈。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

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

  • 1抵皱、通過CocoaPods安裝項(xiàng)目名稱項(xiàng)目信息 AFNetworking網(wǎng)絡(luò)請(qǐng)求組件 FMDB本地?cái)?shù)據(jù)庫組件 SD...
    陽明先生_x閱讀 15,968評(píng)論 3 119
  • 「怎麼會(huì)有這樣的想法呢善榛?」 那天我問我朋友辩蛋,我是不是真的很不會(huì)做人。問的時(shí)候快是隔日凌晨移盆,我本來以為公務(wù)繁忙的他隔...
    張絲蕙閱讀 224評(píng)論 1 1
  • 是誰悼院, 匍匐在乳白色的書桌前,筆綴耕耘 時(shí)而冥思咒循,時(shí)而遠(yuǎn)眺 全然不顧星辰與夏夜的浪漫約會(huì) 又是誰据途, 站立在繁茂的葡...
    南無若樹閱讀 387評(píng)論 7 5
  • 員工流失率:員工流失率是指企業(yè)員工個(gè)人的自愿提出離職。這種流失方式對(duì)企業(yè)來講是不希望的叙甸,企業(yè)一般要設(shè)法控制和避免這...
    雨馨l(fā)閱讀 103評(píng)論 0 0
  • 跟著一群人來瘋的兄弟姐妹們裆蒸,我不知不覺從夏天走到了冬天熔萧,當(dāng)然還會(huì)走向春天。 2017年11月8日 星期三 小雨轉(zhuǎn)多...
    見伊閱讀 1,946評(píng)論 202 111