vue實(shí)戰(zhàn)(11):開(kāi)發(fā)店鋪詳情(二)

懶癌發(fā)作……

本篇有關(guān)于列表滾動(dòng)的內(nèi)容听系,有點(diǎn)復(fù)雜涝滴,好好分析

0. 其它


vue實(shí)戰(zhàn)(1):準(zhǔn)備與資料整理
vue實(shí)戰(zhàn)(2):初始化項(xiàng)目吧黄、搭建底部導(dǎo)航路由
vue實(shí)戰(zhàn)(3):底部導(dǎo)航顯示肺魁、搭建各模塊靜態(tài)頁(yè)面添瓷、添加登錄頁(yè)頁(yè)面與路由
vue實(shí)戰(zhàn)(4):postman測(cè)試數(shù)據(jù)渺蒿、封裝ajax痢士、使用vuex管理狀態(tài)
vue實(shí)戰(zhàn)(5):總結(jié)一
vue實(shí)戰(zhàn)(6):異步顯示數(shù)據(jù)、開(kāi)發(fā)Star組件
vue實(shí)戰(zhàn)(7):完整開(kāi)發(fā)登錄頁(yè)面(一)
vue實(shí)戰(zhàn)(8):完整開(kāi)發(fā)登錄頁(yè)面(二)
vue實(shí)戰(zhàn)(9):總結(jié)二
vue實(shí)戰(zhàn)(10):開(kāi)發(fā)店鋪詳情(一)
vue實(shí)戰(zhàn)(11):開(kāi)發(fā)店鋪詳情(二)
vue實(shí)戰(zhàn)(12):完結(jié) + 附學(xué)習(xí)視頻

1. 分析與引入相關(guān)庫(kù)


  • 靜態(tài)頁(yè)面效果


    靜態(tài)頁(yè)面.png
  • 需要實(shí)現(xiàn)的效果
ID 效果
1 左右兩邊列表可以滑動(dòng)茂装,有回彈效果
2 當(dāng)滑動(dòng)右側(cè)列表時(shí)怠蹂,更新當(dāng)前分類(lèi)(即對(duì)應(yīng)左側(cè)列表類(lèi)型)
3 點(diǎn)擊左側(cè)某個(gè)分類(lèi)時(shí),右側(cè)列表滑動(dòng)到對(duì)應(yīng)類(lèi)型位置
  • 類(lèi)名:current 標(biāo)識(shí)當(dāng)前分類(lèi)(用于顏色變換等)

  • 計(jì)算屬性:currentIndex
    ———— scrollY : 右側(cè)滑動(dòng)的Y軸坐標(biāo)
    ———— tops : 所有右側(cè)分類(lèi) litop 組成的數(shù)組

  • 代碼實(shí)現(xiàn)

ID 需實(shí)現(xiàn)內(nèi)容
1 在滑動(dòng)過(guò)程中少态,實(shí)時(shí)收集 scrollY
2 列表第一次加載顯示后城侧,收集 tops
3 實(shí)現(xiàn)currentIndex計(jì)算邏輯
  • 關(guān)于滑動(dòng)
ID 滑動(dòng)情況(移動(dòng)端)
1 手指一直滑動(dòng),手指不脫離屏幕
2 慣性滑動(dòng)彼妻,手指滑動(dòng)后列表慣性滑動(dòng)
3 編碼滑動(dòng)嫌佑,如點(diǎn)擊事件,點(diǎn)擊類(lèi)型滑動(dòng)到相關(guān)位置

2. 獲取并計(jì)算相關(guān)數(shù)據(jù)


  • 引入組件
    引用 BetterScroll 滑動(dòng)組件與前面引用 Swiper 輪播組件的方式如出一轍,需要進(jìn)行數(shù)據(jù)監(jiān)測(cè)幽邓,獲取的數(shù)據(jù)加載完成后再加載組件
methods: {
    ...mapActions('msite', ['getShopGoods']),
    // 使用組件
    _scrollY () {
      // 左側(cè)類(lèi)型列表
      new BScroll('.menu-wrapper', {
      })
      // 右側(cè)食物列表
      new BScroll('.foods-wrapper', {
      })
    }

  },
computed: {
    ...mapState('msite', ['goods']),
    // 計(jì)算
    currentIndex () {
    }
  },
watch: { // 監(jiān)測(cè)
    goods (value) {
      this.$nextTick(() => { // 數(shù)據(jù)加載完后執(zhí)行
        this._scrollY()
      })
    }
  }
第一步:滑動(dòng)效果實(shí)現(xiàn)
  • 定義收集右側(cè)列表滑動(dòng)的Y軸坐標(biāo) scrollY的方法
    —— 看官網(wǎng)文檔炮温,需要使用 on 方法去進(jìn)行綁定事件
    on方法

    —— 為on方法綁定scroll事件
    自定義事件
  • 滑動(dòng)的方式
    有三種方式,可以都試一下牵舵,看看效果茅特,然后選擇適用的


    probeType
  • 分析選擇
    根據(jù)打印效果選擇,選擇第二種方式最合適
methods: {
    ...mapActions('msite', ['getShopGoods']),
    // 使用組件
    _scrollY () {
      // 左側(cè)類(lèi)型列表
      new BScroll('.menu-wrapper', {
      })
      // 右側(cè)食物列表
      const foodscroll = new BScroll('.foods-wrapper', {
        probeType: 2 // 慣性滑動(dòng)不會(huì)觸發(fā)
      })
      // 操作食物列表
      foodscroll.on('scroll', ({ x, y }) => {
        console.log('橫坐標(biāo):' + x, '縱坐標(biāo):' + y)
        this.scrollY = Math.abs(y) // y軸的值轉(zhuǎn)換為絕對(duì)值
      })
    }
  },
computed: {
    ...mapState('msite', ['goods']),
    // 計(jì)算
    currentIndex () {
    }
  },
watch: { // 監(jiān)測(cè)
    goods (value) {
      this.$nextTick(() => { // 數(shù)據(jù)加載完后執(zhí)行
        this._scrollY()
      })
    }
  }
方式1 效果1 效果2
probeType: 1 在滑動(dòng)時(shí)有輸出祖很,但數(shù)據(jù)不是實(shí)時(shí)輸出 慣性滑動(dòng)時(shí)不輸出
滑動(dòng)第一種類(lèi)型.gif
方式2 效果1 效果2
probeType: 2 在緩慢滑動(dòng)時(shí)有輸出笨鸡,數(shù)據(jù)實(shí)時(shí)輸出 慣性滑動(dòng)時(shí)不輸出
滑動(dòng)第二種類(lèi)型.gif
方式3 效果1 效果2
probeType: 3 輕微滑動(dòng),數(shù)據(jù)輸出迅速,數(shù)據(jù)實(shí)時(shí)輸出 慣性滑動(dòng)時(shí)同樣輸出
滑動(dòng)第三種類(lèi)型.gif

3. 收集 tops

收集右側(cè)列表滑動(dòng)的Y軸坐標(biāo),選擇第二種滑動(dòng)方式

  • 初始化時(shí)收集 tops
// 收集tops
    _initTops () {
      // 初始化,定義最上頭的位置為0
      const toplis = []
      let top = 0
      toplis.push(top)
      // 收集
      // $refs 用于操作dom , foodsUl 為 ref='foodsUl' 設(shè)置在 ul 節(jié)點(diǎn)上累澡,children 為取其下的 li 
      const lis = this.$refs.foodsUl.children
      Array.prototype.slice.call(lis).forEach(li => {
        top += li.clientHeight
        toplis.push(top)
      })
      // 更新數(shù)據(jù)
      this.tops = toplis
      console.log(toplis)
    }
打印的所有tops坐標(biāo)

4. 計(jì)算當(dāng)前分類(lèi)的下標(biāo)

// 計(jì)算當(dāng)前分類(lèi)的下標(biāo)
    currentIndex () {
      // 條件
      const { scrollY, tops } = this
      // 計(jì)算,取區(qū)間返回上一個(gè)值
      const index = tops.findIndex((top, index) => {
        console.log(top, index)
        // 返回結(jié)果: scrollY >= 當(dāng)前top && scrollY < 下一個(gè)top
        return scrollY >= top && scrollY < tops[index + 1]
      })
      return index
    }
  • 鏈接:Array.prototype.findIndex()

    滑動(dòng)更新左側(cè)分類(lèi).gif

  • 解決慣性滑動(dòng)的 bug
    慣性滑動(dòng)的時(shí)候左側(cè)分類(lèi)不隨著更新
    解決辦法:查看 BetterScroll 官網(wǎng),添加滑動(dòng)結(jié)束的監(jiān)聽(tīng)

    監(jiān)聽(tīng)滑動(dòng)結(jié)束.png

// 監(jiān)聽(tīng)滑動(dòng)結(jié)束
      foodscroll.on('scrollEnd', ({ x, y }) => {
        // console.log('橫坐標(biāo):' + x, '縱坐標(biāo):' + y)
        this.scrollY = Math.abs(y) // 轉(zhuǎn)換為絕對(duì)值
      })

5. 點(diǎn)擊左側(cè)分類(lèi)滑動(dòng)

  • 添加點(diǎn)擊事件
    <li class="menu-item " v-for="(good, index) in goods" :key="index" :class="{current:index === currentIndex}" @click="clickMenuItem(index)">

  • 查看 BetterScroll 官網(wǎng)旅东,找到相關(guān)方法 scrollTo

    scrollTo方法.png

  • 方法

// 左側(cè)分類(lèi)列表點(diǎn)擊事件
    clickMenuItem (index) {
      console.log(index)
      // 得到目標(biāo)位置的scrollY
      const scrollY = this.tops[ index ]
      // 立即更新scrollY(讓點(diǎn)擊的分類(lèi)項(xiàng)成為當(dāng)前分類(lèi))
      this.scrollY = scrollY
      // 平滑滑動(dòng)右側(cè)列表
      this.foodscroll.scrollTo(0, -scrollY, 400)
    }
點(diǎn)擊分類(lèi)滑動(dòng).gif

6. 結(jié)束

這個(gè)滑動(dòng)的功能看起來(lái)不難,但是分析起來(lái)感覺(jué)還是有些道道的;
前段時(shí)間有點(diǎn)生病拷姿,電腦又壞了陡舅,最坑爹的是剛過(guò)保修期維修花了500,真是花錢(qián)容易賺錢(qián)難,加之最近很浮躁,導(dǎo)致根本無(wú)心學(xué)習(xí);
拖到現(xiàn)在,這個(gè)星期這個(gè)項(xiàng)目必結(jié)束聚至。

點(diǎn)個(gè)贊唄坦报!
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末信不,一起剝皮案震驚了整個(gè)濱河市抽活,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌锰什,老刑警劉巖下硕,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異汁胆,居然都是意外死亡梭姓,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)嫩码,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)誉尖,“玉大人,你說(shuō)我怎么就攤上這事铸题≌∷。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵丢间,是天一觀的道長(zhǎng)探熔。 經(jīng)常有香客問(wèn)我,道長(zhǎng)千劈,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任牌捷,我火速辦了婚禮墙牌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘暗甥。我一直安慰自己喜滨,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布撤防。 她就那樣靜靜地躺著虽风,像睡著了一般。 火紅的嫁衣襯著肌膚如雪寄月。 梳的紋絲不亂的頭發(fā)上辜膝,一...
    開(kāi)封第一講書(shū)人閱讀 51,631評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音漾肮,去河邊找鬼厂抖。 笑死,一個(gè)胖子當(dāng)著我的面吹牛克懊,可吹牛的內(nèi)容都是我干的忱辅。 我是一名探鬼主播七蜘,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼墙懂!你這毒婦竟也來(lái)了橡卤?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤损搬,失蹤者是張志新(化名)和其女友劉穎碧库,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體场躯,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡谈为,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了踢关。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片伞鲫。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖签舞,靈堂內(nèi)的尸體忽然破棺而出秕脓,到底是詐尸還是另有隱情,我是刑警寧澤儒搭,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布吠架,位于F島的核電站,受9級(jí)特大地震影響搂鲫,放射性物質(zhì)發(fā)生泄漏傍药。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一魂仍、第九天 我趴在偏房一處隱蔽的房頂上張望拐辽。 院中可真熱鬧,春花似錦擦酌、人聲如沸俱诸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)睁搭。三九已至,卻和暖如春笼平,著一層夾襖步出監(jiān)牢的瞬間园骆,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工寓调, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留遇伞,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓捶牢,卻偏偏與公主長(zhǎng)得像鸠珠,于是被迫代替她去往敵國(guó)和親巍耗。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

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

  • 基于Vue的一些資料 內(nèi)容 UI組件 開(kāi)發(fā)框架 實(shí)用庫(kù) 服務(wù)端 輔助工具 應(yīng)用實(shí)例 Demo示例 element★...
    嘗了又嘗閱讀 1,154評(píng)論 0 1
  • UI組件 element- 餓了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的組件庫(kù) m...
    小姜先森o0O閱讀 9,492評(píng)論 0 72
  • UI組件 element- 餓了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的組件庫(kù) m...
    柴東啊閱讀 15,856評(píng)論 2 140
  • 我想找個(gè)女朋友 一起上課 一起去圖書(shū)館 一起撐起一把傘 一起牽著手走遍學(xué)校的每個(gè)角落 然而現(xiàn)實(shí)是每天早起一個(gè)人去食...
    hi武林高手閱讀 2,750評(píng)論 60 12
  • 早上我和睿睿一起去上學(xué)渐排,到教室門(mén)口和瑋瑋媽媽陽(yáng)陽(yáng)媽媽匯合炬太。 太陽(yáng)亮亮的,溫度也怡人驯耻,又從穿毛衣到了穿半袖的季節(jié)亲族。 ...
    a晟睿閱讀 238評(píng)論 3 1