vant-ui框架的一个bug(解决切换后onload不触发)
前几天做的项目里有用到下拉刷新。使用了vant-ui里的
瀑布流滚动加载,用于控制长列表的展示
先说使用
1.用npm下载该模块包
npm i vant -S
2.引入组件
官方提供了三种方法。(我使用了第三种,全局引入方法)
方式一. 使用 (推荐)
babel-plugin-import 是一款 babel 插件,它会在编译过程中将 import 的写法自动转换为按需引入的方式
# 安装 babel-plugin-import 插件 npm i babel-plugin-import -D // .babelrc 中配置 // 注意webpack 1 无需设置 libraryDirectory { "plugins": [ ["import", { "libraryName": "vant", "libraryDirectory": "es", "style": true }] ] } // 对于使用 babel7 的用户,可以在 babel.config.js 中配置 module.exports = { plugins: [ ['import', { libraryName: 'vant', libraryDirectory: 'es', style: true }, 'vant'] ] };
接着你可以在代码中直接引入 Vant 组件,插件会自动将代码转化为方式二中的按需引入形式
import { Button, Cell } from 'vant';
如果你在使用 TypeScript,可以使用 实现按需引入
方式二. 按需引入组件
在不使用插件的情况下,可以手动引入需要的组件
import Button from 'vant/lib/button';
import 'vant/lib/button/style';
方式三. 导入所有组件(在main.js中引入)
import Vue from 'vue'; import Vant from 'vant'; import 'vant/lib/index.css'; Vue.use(Vant);
注意配置 babel-plugin-import 插件后将不允许导入所有组件
引入成功后使用
<van-list v-model="loading" :finished="finished" @load="onLoad"> <v-bookOrder :list="list" :type="type" :idType="idType" @reflush = "submitHandler"> </v-bookOrder> </van-list> <!-- //空页面 --> <div class="empty" v-if="list.length==0&&!loading"> <img src="../../assets/icon_kong_dingdan@2x.png"/> <div>暂无预约~</div> </div>
loading为false是加载中,finished为true是已结束状态,onLoad是执行函数(分页添加list的值),里面的v-bookOrder是自己写的组件。
初始化loading为false,finished为false。
一切ok。
但项目里,加载的list,页面上有个切换的tab,实现切换不同的类型,加载不同的list的功能。vant-ui的list就有个bug,当切换tab的时候,它的onload没方法自动触发。在当前标签页,如果列表已经加载完毕再去切换,onload就可以实现自动触发。(很多人给官方提这个问题,官方就是不修改)。
狼蚁网站SEO优化给出解决方案。
在切换tab后执行初始化函数
initialization(){ this.list = []; this.page = 1; this.loading = true;//下拉加载中 this.finished = false;//下拉结束 if(this.loading){ this.onLoad(); } },
list清空,page=1表示第一页,将loading设置为true,一定触发一次onload,
onLoad() { setTimeout(async () => { let res = await this.$ajax.get({ limit:this.pageSize, page:this.page, keyword:this.value1 },'/order/businesslist/'+this.type, res=>{ if(res.code==0){ this.list = this.list.concat(res.data.list) this.loading = false; if(this.list.length >= res.data.total){ this.finished = true; } this.page++; } else{ this.$dialog.toast({ mes: res.msg, timeout: 1500 }); }},err=>{ this.$dialog.toast({ mes: "出错了~", timeout: 1500 }); }) }, 500); },
在第一次onload的过程中将loading设置为false,则触发第二次loading,当执行到满足结束条件的时候,finished为true,结束加载。bug就解决啦~
补充知识vant 框架van-list重复触发加载函数的问题
在使用van-list组件的时候,为了隐藏ios手机右侧的滚动条,我给了组件一个overflow-x:hidden属性,官方说这个属性会导致重复触发van-list的加载,
我去掉这个属性仍然不管用,而且这个属性又是必须保留的,我又给了他一个固定的高度,就不会重复触发加载了,注意一定要是固定的高度,
设置height:100%仍然是不管用的,记录一下这个问题。
以上这篇vant-ui框架的一个bug(解决切换后onload不触发)就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程