中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue基于better-scroll實現左右聯動頁面的方法

發布時間:2020-07-01 09:46:15 來源:億速云 閱讀:224 作者:清晨 欄目:開發技術

這篇文章主要介紹vue基于better-scroll實現左右聯動頁面的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

界面如下:

vue基于better-scroll實現左右聯動頁面的方法

vue模板

<template>
 <div class="goods">
 <div class="menu-wrapper">
  <ul>
  <li class="menu-item" v-for="(good, index) in goods" :key="index" 
   :class="{current: currentIndex===index}" @click="clickMenuItem(index)">
   <span class="text bottom-border-1px">
   <img :src="good.icon" class="icon" v-if="good.icon">
   {{good.name}}
   </span> 
  </li>
  </ul>
 </div>
 <div class="foods-wrapper">
  <ul ref="foodsWrapperUl">
  <li class="food-list food-list-hook" v-for="(good, index) in goods" :key="index">
   <h2 class="title">{{good.name}}</h2>
   <ul>
   <li class="food-item bottom-border-1px" v-for="(food, index) in good.foods" :key="index">
    <div class="icon">
    <img :src="food.icon" width="57" height="57" alt="">
    </div>
    <div class="content">
    <h3 class="name">{{food.name}}</h3>
    <p class="desc">{{food.description}}</p>
    <div class="extra">
     <span class="count">月售{{food.sellCount}}份</span>
     <span>好評{{food.rating}}%</span>
    </div>
    <div class="price">
     <span class="now">¥{{food.price}}</span>
     <span class="old" v-if="food.oldPrice">¥{{food.oldPrice}}</span>
    </div>
    <div class="cartcontrol-wrapper"><cartcontrol :food="food"/></div>
    </div>
   </li>
   </ul>
  </li>
  </ul>
 </div>
 </div>
</template>

<script>
 import BScroll from 'better-scroll'
 import { mapState } from 'vuex'
 import CartControl from "../../../components/CartControl/CartControl"
 export default {
 data() { 
  return {
  scrollY: 0,
  tops: []
  }
 },
 mounted () {
  this.$store.dispatch('getShopGoods', () => { //回調函數,等到action中執行
  this.$nextTick(() => { //頁面更新后再使用滾動組件,獲取DOM高度
   this._initScroll();
   this._initTops();
  })
  })
 },
 methods: {
  _initScroll() {
  new BScroll('.menu-wrapper', {
   click:true
  })

  this.foodsScroll = new BScroll('.foods-wrapper', {
   probeType: 2,
   click: true
  })

  this.foodsScroll.on('scroll', (pos) => {
   this.scrollY = Math.abs(pos.y);
  })

  this.foodsScroll.on('scrollEnd', (pos) => {
   this.scrollY = Math.abs(pos.y);
  })
  },

  _initTops () {
  const tops = [];
  let top = 0;
  tops.push(top);
  const lis = this.$refs.foodsWrapperUl.getElementByClassName('food-list-hook');
  Array.prototype.slice.call(lis).forEach((li, index) => {
   top += li.clientHeight;
   tops.push(top);
  })
  this.tops = tops;
  },

  clickMenuItem (index) {
  const top = this.tops[index];
  this.scrollY = top;
  this.foodsScroll.scrollTo(0, -top, 300)
  }
 },

 computed: {
  ...mapState(['goods']),
  currentIndex () {
  return this.tops.findIndex((top, index) => {
   return this.scrollY>=top && this.scrollY<this.tops[index+1]
  })
  }
 }
 }
</script>//也可以不用計算屬性,直接在data中定義currentIndex,改動時賦新值,那頁面自然跟著更新

state.js

goods: [], // 商品列表

action.js

//異步獲取商品列表
 async getShopGoods ({commit}, callback) {
  const result = await reqShopGoods();
  const goods = result.data;
  commit(RECEIVE_GOODS, {goods});
  callback && callback();
 }

mutation.js

[RECEIVE_GOODS](state, {goods}) {
 state.goods = goods
 }

以上是vue基于better-scroll實現左右聯動頁面的方法的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

商南县| 万盛区| 勃利县| 丰县| 瑞金市| 绥棱县| 铁力市| 屏东市| 湘潭县| 丰镇市| 思茅市| 公主岭市| 苗栗市| 淮南市| 临武县| 平乡县| 青岛市| 秭归县| 江华| 托克托县| 大竹县| 宝鸡市| 岢岚县| 凌源市| 枞阳县| 新干县| 南昌县| 虞城县| 苏州市| 丰镇市| 嘉义县| 大方县| 邵东县| 滨海县| 玉门市| 泸水县| 临沭县| 鄂温| 株洲市| 清水河县| 和平县|