mescroll組件

<template>
  <div>
    <!--mescroll滾動區(qū)域的基本結(jié)構(gòu)-->
    <mescroll-vue ref="mescroll" :down="mescrollDown" :up="mescrollUp" @init="mescrollInit">
      <!--內(nèi)容...-->
    </mescroll-vue>
  </div>
</template>

<script>
// 引入mescroll的vue組件
import MescrollVue from 'mescroll.js/mescroll.vue'

export default {
  components: {
    MescrollVue // 注冊mescroll組件
  },
  data () {
    return {
      mescroll: null, // mescroll實(shí)例對象
      mescrollDown: {}, // 下拉刷新的配置. (如果下拉刷新和上拉加載處理的邏輯是一樣的,則mescrollDown可不用寫了)
      mescrollUp: { // 上拉加載的配置.
        callback: this.upCallback, // 上拉回調(diào),此處簡寫; 相當(dāng)于 callback: function(page, mescroll) { }
        page: {
          num: 0, // 當(dāng)前頁 默認(rèn)0,回調(diào)之前會加1; 即callback(page)會從1開始
          size: 10 // 每頁數(shù)據(jù)條數(shù),默認(rèn)10
        },
        htmlNodata: '<p class="upwarp-nodata">-- END --</p>',
        noMoreSize: 5, // 如果列表已無數(shù)據(jù),可設(shè)置列表的總數(shù)量要大于5才顯示無更多數(shù)據(jù);
        toTop: {
          // 回到頂部按鈕
          src: './static/mescroll/mescroll-totop.png', // 圖片路徑,默認(rèn)null,支持網(wǎng)絡(luò)圖
          offset: 1000 // 列表滾動1000px才顯示回到頂部按鈕
        },
        empty: {
          // 列表第一頁無任何數(shù)據(jù)時(shí),顯示的空提示布局; 需配置warpId才顯示
          warpId: 'xxid', // 父布局的id (1.3.5版本支持傳入dom元素)
          icon: './static/mescroll/mescroll-empty.png', // 圖標(biāo),默認(rèn)null,支持網(wǎng)絡(luò)圖
          tip: '暫無相關(guān)數(shù)據(jù)~' // 提示
        }
      },
      dataList: [] // 列表數(shù)據(jù)
    }
  },
  beforeRouteEnter (to, from, next) { // 如果沒有配置回到頂部按鈕或isBounce,則beforeRouteEnter不用寫
    next(vm => {
      // 找到當(dāng)前mescroll的ref,調(diào)用子組件mescroll-vue的beforeRouteEnter方法
      vm.$refs.mescroll && vm.$refs.mescroll.beforeRouteEnter() // 進(jìn)入路由時(shí),滾動到原來的列表位置,恢復(fù)回到頂部按鈕和isBounce的配置
    })
  },
  beforeRouteLeave (to, from, next) { // 如果沒有配置回到頂部按鈕或isBounce,則beforeRouteLeave不用寫
    // 找到當(dāng)前mescroll的ref,調(diào)用子組件mescroll-vue的beforeRouteLeave方法
    this.$refs.mescroll && this.$refs.mescroll.beforeRouteLeave() // 退出路由時(shí),記錄列表滾動的位置,隱藏回到頂部按鈕和isBounce的配置
    next()
  },
  methods: {
    // mescroll組件初始化的回調(diào),可獲取到mescroll對象
    mescrollInit (mescroll) {
      this.mescroll = mescroll // 如果this.mescroll對象沒有使用到,則mescrollInit可以不用配置
    },
    // 上拉回調(diào) page = {num:1, size:10}; num:當(dāng)前頁 ,默認(rèn)從1開始; size:每頁數(shù)據(jù)條數(shù),默認(rèn)10
    upCallback (page, mescroll) {
      // 聯(lián)網(wǎng)請求
      axios.get('xxxxxx', {
        params: {
          num: page.num, // 頁碼
          size: page.size // 每頁長度
        }
      }).then((response) => {
        // 請求的列表數(shù)據(jù)
        let arr = response.data
        // 如果是第一頁需手動制空列表
        if (page.num === 1) this.dataList = []
        // 把請求到的數(shù)據(jù)添加到列表
        this.dataList = this.dataList.concat(arr)
        // 數(shù)據(jù)渲染成功后,隱藏下拉刷新的狀態(tài)
        this.$nextTick(() => {
          mescroll.endSuccess(arr.length)
        })
      }).catch((e) => {
        // 聯(lián)網(wǎng)失敗的回調(diào),隱藏下拉刷新和上拉加載的狀態(tài);
        mescroll.endErr()
      })
    }
  }
}
</script>

<style scoped>
/*通過fixed固定mescroll的高度*/
.mescroll {
  position: fixed;
  top: 44px;
  bottom: 0;
  height: auto;
}
</style>

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市絮供,隨后出現(xiàn)的幾起案子率拒,更是在濱河造成了極大的恐慌,老刑警劉巖窟坐,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異绵疲,居然都是意外死亡哲鸳,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進(jìn)店門盔憨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來徙菠,“玉大人,你說我怎么就攤上這事郁岩⌒霰迹” “怎么了?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵问慎,是天一觀的道長萍摊。 經(jīng)常有香客問我,道長如叼,這世上最難降的妖魔是什么冰木? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮笼恰,結(jié)果婚禮上踊沸,老公的妹妹穿的比我還像新娘。我一直安慰自己社证,他們只是感情好逼龟,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著猴仑,像睡著了一般审轮。 火紅的嫁衣襯著肌膚如雪肥哎。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天疾渣,我揣著相機(jī)與錄音篡诽,去河邊找鬼。 笑死榴捡,一個(gè)胖子當(dāng)著我的面吹牛杈女,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播吊圾,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼达椰,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了项乒?” 一聲冷哼從身側(cè)響起啰劲,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎檀何,沒想到半個(gè)月后蝇裤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡频鉴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年栓辜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片垛孔。...
    茶點(diǎn)故事閱讀 40,040評論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡藕甩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出周荐,到底是詐尸還是另有隱情狭莱,我是刑警寧澤,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布概作,位于F島的核電站贩毕,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏仆嗦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一先壕、第九天 我趴在偏房一處隱蔽的房頂上張望瘩扼。 院中可真熱鬧,春花似錦垃僚、人聲如沸集绰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽栽燕。三九已至罕袋,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間碍岔,已是汗流浹背浴讯。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蔼啦,地道東北人榆纽。 一個(gè)月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像捏肢,于是被迫代替她去往敵國和親奈籽。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評論 2 355

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