inleft
2022-08-10 10572998aa54d61c45df3e334eb01e44a15df729
src/components/group/articleListScorll.vue
@@ -1,18 +1,24 @@
<template>
   <div>
      <div v-infinite-scroll="loadMore" infinite-scroll-disabled="busy" :infinite-scroll-distance="10">
         <div v-for="temp in data">
            <newArticle v-bind="temp"></newArticle>
         <div class="mySecret" v-if="data.length==0">
            <p>空空如也..</p>
         </div>
         <div v-for="(temp,index) in data">
            <newArticle v-bind="temp" :index="index"></newArticle>
            <!-- <box5 v-bind="temp"></box5> -->
         </div>
         <div v-if="loading && !busy" class="demo-loading-container">
            <a-spin />
         </div>
      </div>
      <a-row type="flex" justify="center">
         <div style="position:fixed;bottom: 10px;" id="dddadf">
         <div style="position:fixed;bottom: 10px;">
            <a-pagination @change="onChange" :showQuickJumper="true" :size="size" v-model="current"
               :defaultPageSize="10" :pageSize="pageSize" :total="total" />
               :defaultPageSize="defaultPageSize" :pageSize="pageSize" :total="total" />
         </div>
      </a-row>
@@ -28,30 +34,7 @@
      queryBlogArticleList
   } from '../../api/blogArticle.js'
   var obj1 = {
      "source": babyActicle,
      "title": "陈奕迅-Body Song 歌词",
      "read": 1101,
      "like": 233,
      "folder": "歌词",
      "publishTime": "2021-05-26",
   }
   var obj2 = {
      "source": shijie,
      "title": "这世界那么多人-吉他谱",
      "read": 3101,
      "like": 113,
      "folder": "吉他谱",
      "publishTime": "2020-05-26",
   }
   var obj3 = {
      "source": shijie,
      "title": "遥远的它-吉他谱",
      "read": 201,
      "like": 13,
      "folder": "吉他谱",
      "publishTime": "2022-07-26",
   }
   export default {
      components: {
@@ -61,6 +44,7 @@
      directives: {
         infiniteScroll
      },
      data() {
         return {
            typeId: "",
@@ -69,22 +53,31 @@
            busy: false,
            size: "small",
            total: 1,
            pageSize: 1,
            pageSize: 6,
            current: 1,
            defaultPageSize: 10
         };
      },
      created() {
         this.typeId = this.$route.query.typeId;
      },
      watch: {
         '$route'(to, from) {
            if ("articleList" === to.name) {
            if ("articleList" === to.name || "home" === to.name) {
               this.typeId = this.$route.query.typeId;
            }
         },
         typeId: function(newValue, oldValue) {
            this.busy = true;
            this.$message.info('loading',0.3);
            this.onChange(1);
         }
            this.$message.info('loading', 0.3);
            //有条件不刷新
            if (newValue == undefined && oldValue != "") {
               return
            }
            this.onChange(1);
         },
      },
      activated() {
         window.addEventListener('scroll', this);
@@ -92,22 +85,12 @@
      deactivated() {
         window.removeEventListener('scroll', this);
      },
      beforeMount() {
         queryBlogArticleList({
            pageNo: this.current,
            typeId: this.typeId
         }).then((res) => {
            this.total = Number(res.data.total)
            this.pageSize = Number(res.data.size);
            this.data = res.data.records;
            return res
         })
      },
      methods: {
         onChange(current) {
            this.current = current;
            queryBlogArticleList({
               pageNo: current,
               pageSize: this.pageSize,
               typeId: this.typeId
            }).then((res) => {
               this.busy = false;
@@ -123,6 +106,7 @@
            queryBlogArticleList({
               pageNo: this.current + 1,
               pageSize: this.pageSize,
               typeId: this.typeId
            }).then((res) => {
@@ -152,19 +136,6 @@
   };
</script>
<style>
   /* .test {
      overflow: hidden;
      height: 700px;
   }
   .infinite-container {
      overflow: auto;
   }
   .infinite-container::-webkit-scrollbar {
      display: none;
   } */
   .demo-loading-container {
      position: absolute;
      bottom: 40px;