Skip to content

Latest commit

 

History

History
81 lines (66 loc) · 1.93 KB

README.md

File metadata and controls

81 lines (66 loc) · 1.93 KB

vue-load-select

这个组件已经被封装并且上传到了npm中,如果有需要可以通过安装@johnhom/el-load-select

基于 el-select 二次封装的 Vue.js 下拉加载组件

image

构建

# 安装依赖
npm install

# 启动项目
npm run serve

食用方法

下面的例子将会说明如何在Vue.js中使用该下拉加载组件:

<template>
    <div id="app">
        <load-select
            v-model="selected"
            :data="data"
            :page="page"
            :hasMore="more"
            :request="getData"
        ></load-select>
    </div>
</template>

<script>
// 导入该组件
import loadSelect from "@/components/load-select/index";

export default {
    name: "app",
    components: {
        loadSelect
    },
    data() {
        return {
            selected: "",
            page: 1,
            more: true,
            data: []
        };
    },
    methods: {
        // 传入给load-select组件的函数
        getData({ page = 1, more = false, keyword = "" } = {}) {
            return new Promise(resolve => {
                // 访问后端接口API
                this.requestAPI({ page, keyword }).then(res => {
                    if (more) {
                        this.data = [...this.data, ...res.result];
                    } else {
                        this.data = res.result;
                    }

                    this.page = res.page;
                    let { total, page, size } = res;
                    this.more = page * size < total;
                    this.page = page;
                    resolve();
                });
            });
        }
    }
</script>

项目的运行结果如下:

image

enjoy it!