欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vant van-list下拉加載更多onload事件問題

 更新時間:2023年01月18日 10:01:35   作者:易小花  
這篇文章主要介紹了vant van-list下拉加載更多onload事件問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vant van-list下拉加載更多onload事件

問題描述

van-list編寫下拉加載更多,利用van-list自帶的下拉加載事件@load="onLoad",但是發(fā)現(xiàn)有次數(shù)限制,仍有部分條件下無法下拉加載更多。

后來發(fā)現(xiàn)原因,執(zhí)行完,之后finished恢復(fù)false,同時將當(dāng)前頁恢復(fù)為1,不寫的話,代碼不會自己恢復(fù),因為這些參數(shù)是全局變量,所以會保留最后執(zhí)行之后的結(jié)果。

所以,在代碼執(zhí)行前要做一個恢復(fù)。細(xì)節(jié)很重要,因為這個細(xì)節(jié),耽誤了很久時間。

this.currentPage = 1;
//每次走完函數(shù),將當(dāng)前頁恢復(fù)至1,防止后面累加,導(dǎo)致點擊別的篩選條件時無效,返回finished-text
this.finished = false;
//同樣,也要將finished恢復(fù),否則,執(zhí)行別的篩選條件時,會顯示finished-text,并且導(dǎo)致明明還有數(shù)據(jù),但是不會加載出來.

主要代碼如下

<van-list
	v-model="loading"
	:finished="finished"
	finished-text="我是有底線的~"
	@load="onLoad">//list自帶的下拉刷新事件
	<van-row
		v-for="(item,key) of Array"
		:key="key"
   </van-row>//循環(huán),顯示列表
</van-list>
selType(type) {//從前端的點擊事件獲得type
	this.selectedType = type;
	console.log(this.selectedType);
	this.currentPage = 1;
	//每次走完函數(shù),將當(dāng)前頁恢復(fù)至1,防止后面累加,導(dǎo)致點擊別的篩選條件時無效,返回finished-text
	this.finished = false;
	//同樣,也要將finished恢復(fù),否則,執(zhí)行別的篩選條件時,會顯示finished-text,并且導(dǎo)致明明還有數(shù)據(jù),但是不會加載出來.
	this.onLoad();
},
onLoad(){
	this.search();
}

search() {//調(diào)用查詢的接口
	let params = {
		type: this.selectedType, 
		index: this.currentPage,//頁數(shù)
		size: this.pageSize,//每頁個數(shù)
	}
.....(接口)(params).then(res => {
	console.log(res);
    this.dataTotal = res.total;
    //進(jìn)行判斷
	if(this.dataTotal <= this.pageSize){
		this.Array = res.data.list;
		console.log(this.Array);
	}else{
		this.currentPage++;
		let arr = res.data.data.list;
		this.Array = this.Array.concat(arr);
	};
	// 加載狀態(tài)結(jié)束
	this.loading = false;
	// 數(shù)據(jù)全部加載完成
	if (this.Array.length >= this.dataTotal) {
		this.finished = true;//結(jié)束,顯示我也是有底線的
	};
    });
}

vant van-list的使用及一些坑的解決

第一步

要使用vant組件,安裝好vant,npm i vant -S

第二步

在你要用到的地方j(luò)s中引入,或者在src/main.js里面引入

import Vue from ‘vue‘;
import { List } from ‘vant‘;

Vue.use(List);

這里我引入的地方是我要用到的js文件中

第三步

在template中引用

第四步

js中重要代碼

data(){
    return{
      content_list: [],
      	loading: false,//加載狀態(tài)
      	finished: false,//是否加載
      	count_page: 1,//加載頁數(shù)
   	count_num: 4//每頁限制條數(shù)
    }
 },
  methods:{
     list_onload_more: function () {
          var _this = this;
          _this.count_page += 1;
          // 請求數(shù)據(jù)
          _this.get_course_list();
      }
      ,get_course_list:function(){
      	   var _this = this;
		   var params ={};
           params.page = _this.count_page;
           params.num = _this.count_num;
           index_rpc.get_collection_course(params,function (data) {
               if(data.error_code == 0) {
                   var item = data.data || [];
                   _this.count = data.count;
                   if (params.count_page == 1){
                       _this.content_list = [];
                   }
                   item.forEach(function(val) {
                       _this.content_list.push(val);
                   })
                   //這里是用于判斷什么時候所有數(shù)據(jù)加載完畢,然后進(jìn)行是否進(jìn)行加載關(guān)閉
                   if(_this.count_num * _this.count_page >= _this.count) {
                       _this.finished = true;
                   }else {
                       _this.finished = false;
                   }
               }else{
                   _this.count = 0;
                   _this.content_list = [];
                   _this.finished = true;
               }
               //最后數(shù)據(jù)加載完后不要忘記將loading改為false
               _this.loading = false;
           })
      }
  }

兩個事情跳轉(zhuǎn):

第五步

解決遇到的坑

這里我講一下我遇到的一些關(guān)于該組件的問題解決方法。

首先, onload在加載時只觸發(fā)一次,頁面向下滾動時,onload并不加載,你可以在獲取數(shù)據(jù)的時候手動在前面加一個_this.loading = false。

其次,如果數(shù)據(jù)一次全加載完了,說明你表格渲染的高度沒有固定,或者是高度被撐開了,所以才會導(dǎo)致數(shù)據(jù)會一次加載完畢。設(shè)置100%也無效,這時你要設(shè)置高度。

然后如果一直顯示加載中,無法關(guān)閉,這時你要在獲取數(shù)據(jù)里面做一個判斷,判斷數(shù)據(jù)是否已經(jīng)全部獲取,獲取了就給_this.finished = true,即關(guān)閉加載。

最后&#xff0c;就是css樣式問題,列表元素使用了float需要使用類名vant-clearfix清除float,否則會出現(xiàn)請求被多次觸發(fā)的問題。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于vue里頁面的緩存詳解

    關(guān)于vue里頁面的緩存詳解

    今天小編就為大家分享一篇關(guān)于vue里頁面的緩存詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Vue.js圖片預(yù)覽插件使用詳解

    Vue.js圖片預(yù)覽插件使用詳解

    Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式框架。這篇文章主要介紹了Vue.js圖片預(yù)覽插件的相關(guān)知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-08-08
  • vue中路由傳參6種方式總結(jié)

    vue中路由傳參6種方式總結(jié)

    這篇文章主要為大家詳細(xì)介紹了vue中路由傳參6種方式,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-08-08
  • vue.js項目中實用的小技巧匯總

    vue.js項目中實用的小技巧匯總

    這篇文章主要給大家介紹了關(guān)于vue.js項目中實用的小技巧,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • 前端實現(xiàn)不同角色登入展示不同頁面效果實例

    前端實現(xiàn)不同角色登入展示不同頁面效果實例

    要實現(xiàn)不同角色登錄跳轉(zhuǎn)不同的前端頁面,可以在登錄成功后,根據(jù)用戶的角色信息,使用路由跳轉(zhuǎn)到不同的頁面,這篇文章主要給大家介紹了關(guān)于前端實現(xiàn)不同角色登入展示不同頁面效果的相關(guān)資料,需要的朋友可以參考下
    2024-08-08
  • Vue CLI3基礎(chǔ)學(xué)習(xí)之pages構(gòu)建多頁應(yīng)用

    Vue CLI3基礎(chǔ)學(xué)習(xí)之pages構(gòu)建多頁應(yīng)用

    這篇文章主要給大家介紹了關(guān)于Vue CLI3基礎(chǔ)學(xué)習(xí)之pages構(gòu)建多頁應(yīng)用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Vue CLI3具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Vue v2.5 調(diào)整和更新不完全問題

    Vue v2.5 調(diào)整和更新不完全問題

    這篇文章主要介紹了Vue v2.5 調(diào)整和更新不完全問題的相關(guān)資料,需要的朋友可以參考下
    2017-10-10
  • Vue解決echart在element的tab切換時顯示不正確問題

    Vue解決echart在element的tab切換時顯示不正確問題

    這篇文章主要介紹了Vue解決echart在element的tab切換時顯示不正確問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 詳解VUE前端按鈕權(quán)限控制

    詳解VUE前端按鈕權(quán)限控制

    這篇文章主要介紹了VUE前端按鈕權(quán)限控制,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue-element-admin如何設(shè)置默認(rèn)語言

    vue-element-admin如何設(shè)置默認(rèn)語言

    這篇文章主要介紹了vue-element-admin如何設(shè)置默認(rèn)語言,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論