ragaFramework輪播圖問題跟蹤

問題復(fù)現(xiàn)

首先復(fù)制官方代碼畦娄,可以顯示輪播圖又沾。


image.png
image.png

但是出現(xiàn)的情況是,點(diǎn)擊右上角的切換下一張,直接切換了兩張輪播圖熙卡。

問題跟蹤

chrome 瀏覽器F12加斷點(diǎn)杖刷。首先已知這個系統(tǒng)自帶的輪播圖插件是基于bootstrap的,打開這個js再膳,然后搜索carousel
在407行挺勿,找到如下代碼

  Carousel.prototype.next = function () {
    if (this.sliding) return
    return this.slide('next')
  }

如果判斷為真曲横,直接返回喂柒。否則,進(jìn)入this.slide('next')
斷點(diǎn)進(jìn)入方法。417行

  Carousel.prototype.slide = function (type, next) {
    ...
        ...
        //這里把sliding設(shè)置為true,那么407的方法應(yīng)該直接return的誊薄,而斷點(diǎn)時發(fā)現(xiàn)蒸绩,那里為false,
    //所以重點(diǎn)關(guān)注這個值
    this.sliding = true
        ...
    var slidEvent = $.Event('slid.bs.carousel', { relatedTarget: relatedTarget, direction: direction }) // yes, "slid"
    if ($.support.transition && this.$element.hasClass('slide')) {
      //如果進(jìn)入這個代碼塊啡莉,未更改sliding的值,依然為true
      $next.addClass(type)
      if (typeof $next === 'object' && $next.length) {
        $next[0].offsetWidth // force reflow
      }
      $active.addClass(direction)
      $next.addClass(direction)
      $active
        .one('bsTransitionEnd', function () {
          $next.removeClass([type, direction].join(' ')).addClass('active')
          $active.removeClass(['active', direction].join(' '))
          that.sliding = false
          setTimeout(function () {
            that.$element.trigger(slidEvent)
          }, 0)
        })
        .emulateTransitionEnd(Carousel.TRANSITION_DURATION)
    } else {
      $active.removeClass('active')
      $next.addClass('active')
      //如果進(jìn)入這個代碼塊,則重置為false
      this.sliding = false
      this.$element.trigger(slidEvent)
    }

    isCycling && this.cycle()

    return this
  }

觀察代碼昭娩,如果進(jìn)入else,407行的this.sliding為false黍匾。而根據(jù)斷點(diǎn)調(diào)試栏渺,的卻進(jìn)入了else分支。
觀察if判斷

if ($.support.transition && this.$element.hasClass('slide')) 

斷點(diǎn)發(fā)現(xiàn)&&前為true锐涯,也即&&后的判定磕诊,我們要把他改為true,這里判定了element是否有slide class。

解決問題

為這個element設(shè)置slide的class霎终,問題解決

 echo Carousel::widget([
                        'items' => $slides,
                        'options'=>['class'=>'slide']
                    ]);

深入研究

斷點(diǎn)跟蹤框架中的Carousel控件滞磺,它根據(jù)options參數(shù)來設(shè)置class屬性,而代碼中的卻沒有默認(rèn)設(shè)置slide的class莱褒。
問題已經(jīng)解決击困,但是為什么會出現(xiàn)這種問題就很費(fèi)解了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末保礼,一起剝皮案震驚了整個濱河市沛励,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌炮障,老刑警劉巖目派,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異胁赢,居然都是意外死亡企蹭,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進(jìn)店門智末,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谅摄,“玉大人,你說我怎么就攤上這事系馆∷湍” “怎么了?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵由蘑,是天一觀的道長闽寡。 經(jīng)常有香客問我,道長尼酿,這世上最難降的妖魔是什么爷狈? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮裳擎,結(jié)果婚禮上涎永,老公的妹妹穿的比我還像新娘。我一直安慰自己鹿响,他們只是感情好羡微,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著惶我,像睡著了一般妈倔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上指孤,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天启涯,我揣著相機(jī)與錄音贬堵,去河邊找鬼。 笑死结洼,一個胖子當(dāng)著我的面吹牛黎做,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播松忍,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼蒸殿,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了鸣峭?” 一聲冷哼從身側(cè)響起宏所,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎摊溶,沒想到半個月后爬骤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡莫换,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年霞玄,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拉岁。...
    茶點(diǎn)故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡坷剧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出喊暖,到底是詐尸還是另有隱情惫企,我是刑警寧澤,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布陵叽,位于F島的核電站狞尔,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏咨跌。R本人自食惡果不足惜沪么,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一硼婿、第九天 我趴在偏房一處隱蔽的房頂上張望锌半。 院中可真熱鬧,春花似錦寇漫、人聲如沸刊殉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽记焊。三九已至,卻和暖如春栓撞,著一層夾襖步出監(jiān)牢的瞬間遍膜,已是汗流浹背碗硬。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留瓢颅,地道東北人恩尾。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像挽懦,于是被迫代替她去往敵國和親翰意。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評論 2 355

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