index.vue 4.09 KB
<template>
    <div>
        <template v-if="productList.length">
            <Order :config="orderConfig" :val="order">
            </Order>
            <List :data="productList"></List>
        </template>
        <div class="empty-tip" v-if="empty">
            <i class="icon icon-search"></i>
            <p class="empty-tip-cn">未找到相关商品</p>
            <p class="empty-tip-en">Did not find the relevant goods</p>
        </div>
    </div>
</template>
<script>
    const Vue = require('vue');
    const $ = require('jquery');
    const lazyload = require('vue-lazyload');
    const infinitScroll = require('vue-infinite-scroll');

    const qs = require('yoho-qs');
    const bus = require('common/vue-bus');
    const tip = require('common/tip');

    const order = require('component/product/order.vue');
    const list = require('component/product/list.vue');

    Vue.use(lazyload);
    Vue.use(infinitScroll);

    require('common/vue-filter');

    module.exports = {
        el: '#product-search',
        data: function() {
            return {
                orderConfig: global.orderConfig,
                filterConfig: global.filterConfig,

                // query
                url: '/search.json',
                order: '',
                query: qs.query,
                page: 0, // 未搜索 page=0; 全部加载完 page = totalPage; 无数据: page !=0 && productList.length=0
                totalPage: null,

                // 产品列表
                productList: [],

                // state
                inSearching: false // 请求中
            };
        },
        computed: {
            // 无数据
            empty: function() {
                return this.page !== 0 && !this.productList.length;
            }
        },
        components: {
            list,
            order
        },
        methods: {
            search: function() {
                const self = this;
                const nextPage = this.page + 1;

                if (this.inSearching) {
                    return;
                }

                // page = 0, 始终执行搜索
                if (this.page && nextPage > this.totalPage) {
                    return;
                }

                this.inSearching = true;
                console.log(nextPage);
                $.get(this.url, {
                    order: this.order, // 排序 信息
                    query: this.query,
                    page: nextPage
                })
                .done(res => {
                    if (res.code === 200) {
                        self.page = res.data.page;
                        self.totalPage = res.data.pageTotal;
                        self.$set('productList', self.productList.concat(res.data.productList));
                    }
                })
                .fail(error => {
                    tip('网络出错~');
                })
                .always(() => {
                    self.inSearching = false;
                });
            },

            /**
             *  清空数据(page=0) 重新搜索
             */
            research: function() {
                this.page = 0;
                this.$set('productList', []);
                this.search();
            }
        },
        watch: {
            /* order 改变 都会触发 重新搜索 */
            order: function() {
                this.research();
            }
        },

        created: function() {
            const self = this;


            bus.$on('list.paging', function() {
                self.search();
            });

            bus.$on('order.change', function({
                val
            }) {
                self.order = val;
            });

            this.search();
        }
    };

</script>
<style>
    .empty-tip {
        margin-top: 380px;
        color: #b0b0b0;
        text-align: center;
        .icon-search {
            display: inline-block;
            font-size: 200px;
            margin-bottom: 56px;
        }
    }

    .empty-tip-cn {
        font-size: 34px;
        margin-bottom: 30px;
    }

    .empty-tip-en {
        font-size: 20px;
    }

</style>