亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vant van-list下拉加載更多onload事件問(wèn)題

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

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

問(wèn)題描述

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

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

所以,在代碼執(zhí)行前要做一個(gè)恢復(fù)。細(xì)節(jié)很重要,因?yàn)檫@個(gè)細(xì)節(jié),耽誤了很久時(shí)間。

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

主要代碼如下

<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) {//從前端的點(diǎn)擊事件獲得type
	this.selectedType = type;
	console.log(this.selectedType);
	this.currentPage = 1;
	//每次走完函數(shù),將當(dāng)前頁(yè)恢復(fù)至1,防止后面累加,導(dǎo)致點(diǎn)擊別的篩選條件時(shí)無(wú)效,返回finished-text
	this.finished = false;
	//同樣,也要將finished恢復(fù),否則,執(zhí)行別的篩選條件時(shí),會(huì)顯示finished-text,并且導(dǎo)致明明還有數(shù)據(jù),但是不會(huì)加載出來(lái).
	this.onLoad();
},
onLoad(){
	this.search();
}

search() {//調(diào)用查詢的接口
	let params = {
		type: this.selectedType, 
		index: this.currentPage,//頁(yè)數(shù)
		size: this.pageSize,//每頁(yè)個(gè)數(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,//加載頁(yè)數(shù)
   	count_num: 4//每頁(yè)限制條數(shù)
    }
 },
  methods:{
     list_onload_more: function () {
          var _this = this;
          _this.count_page += 1;
          // 請(qǐng)求數(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í)候所有數(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;
           })
      }
  }

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

第五步

解決遇到的坑

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

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

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

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

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

總結(jié)

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

相關(guān)文章

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

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

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

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

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

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

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

    vue.js項(xiàng)目中實(shí)用的小技巧匯總

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

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

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

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

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

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

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

    Vue解決echart在element的tab切換時(shí)顯示不正確問(wèn)題

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

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

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

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

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

最新評(píng)論