vue2+element-ui 实现下拉框滚动加载

一、自定义滚动指令。

VUE.directive(

'el-select-loadmore': {

bind(el, binding) {

const SELECTWRAP_DOM = el.querySelector('.el-select-dropdown .el-select-dropdown__wrap')

SELECTWRAP_DOM.addEventListener('scroll', function () {

/**

* scrollHeight 获取元素内容高度

* scrollTop 获取或者设置元素的偏移值,常用于计算滚动条的位置,当一个元素的容器没有产生垂直方向的滚动条,那它的scrollTop值默认为0

* clientHeight 获取元素的可见高度

* 如果元素滚动到底,下面的等式返回true,没有则返回false

**/

const condition = (this.scrollHeight - this.scrollTop) <= (this.clientHeight + 10);

if (condition) {

binding.value();

}

})

}

}

})

二、绑定方法。

data() {

return {

adGroupList: [],

adGroupQuery: {

pageNum: 1,

pageSize: 10

},

typeTotal: 0,

selectLoading: false,

};

},

methods: {

// 获取后端数据

getAdGroupList() {

this.selectLoading = true

const params = {

page: this.adGroupQuery.currentPage,

pageSize: this.adGroupQuery.pageSize,

param: {

adGroup: this.adGroupQuery.adGroup

}

}

getAdGroupList(params).then(

response => {

this.selectLoading = false

this.adGroupList = [...this.adGroupList, ...response.result];

this.typeTotal = response.count

}

);

},

//下拉框搜索方法

remoteMethod(query) {

this.adGroupQuery.adGroup= query

this.adGroupQuery.pageNum = 1

this.adGroupList= []

this.getAdGroupList()

},

//滚动加载

loadmore() {

if (this.typeTotal > this.adGroupList.length) {

this.adGroupQuery.pageNum++;

this.getAdGroupList();

}

}

},

三、组件绑定属性。

<el-select

v-model="form.materialId"

v-el-select-loadmore="loadmore"

placeholder="请输入AD组查询"

filterable

remote

clearable

:remote-method="remoteMethod"

style="width:100%">

<el-option v-for="(item, index) in typeList" :key="index" :label="item.name" :value="item.id">

</el-option>

</el-select>

相关推荐
妙团团几秒前
React学习之自定义tab组合组件
javascript·学习·react.js
2601_949809596 分钟前
flutter_for_openharmony家庭相册app实战+隐私设置实现
android·javascript·flutter
2601_949593658 分钟前
React Native 鸿蒙跨平台开发:LinearGradient 渐变动画效果
javascript·react native·react.js
黄筱筱筱筱筱筱筱10 分钟前
7.适合新手小白学习Python的异常处理(Exception)
java·前端·数据库·python
qq_1777673710 分钟前
React Native鸿蒙跨平台音乐播放器涉及实时进度更新、播放控制、列表交互、状态管理等核心技术点
javascript·react native·react.js·ecmascript·交互·harmonyos
QQ179580639611 分钟前
基于springboot+vue的hive的歌曲音乐筛选推荐系统网站(源码+lw+部署文档+讲解等)
vue.js·hive·spring boot
雨季66613 分钟前
Flutter 三端应用实战:OpenHarmony “极简文本字符计数器”——量化表达的尺度
开发语言·flutter·ui·交互·dart
2501_9209317014 分钟前
React Native鸿蒙跨平台实现了简单的商品图片轮播功能,为用户提供了直观的商品图片浏览体验,帮助用户全面了解商品外观
javascript·react native·react.js·ecmascript·harmonyos
Yeats_Liao16 分钟前
微调决策树:何时使用Prompt Engineering,何时选择Fine-tuning?
前端·人工智能·深度学习·算法·决策树·机器学习·prompt
晚霞的不甘17 分钟前
Flutter for OpenHarmony 实现 iOS 风格科学计算器:从 UI 到表达式求值的完整解析
前端·flutter·ui·ios·前端框架·交互