js realizes the dynamic loading of data by waterfall flow bottoming out

js realizes the dynamic loading of data by waterfall flow bottoming out

This article shares with you the specific code of js to realize the dynamic loading of data when the waterfall flow touches the bottom. For your reference, the specific content is as follows


// onScrollEvent scroll bar event <div class="box" ref="box" @mousewheel="onScrollEvent">
    //The content of each block start
      <div class="boxItemStyle" v-for="(userTag, i) in dataSource" :key="i" ref="boxItemStyle">
        <a-tag class="moreStyle" @click="more(userTag.primaryParam)"> More></a-tag>
        <div v-for="item in userTag.userTag" :key="item.code">
          <p>
            {{ item.name }}:
            {{ item.value }}
          </p>
        </div>
      </div>
      //Contents in each block end
</div>

Waterfall layout

waterFall() {
  // Subtract the width of the margin var pageWidth = this.$refs.box.offsetWidth - 200
      var columns = 4; //Define a row with 4 columns var itemWidth = parseInt(pageWidth / columns);
      var arr = [];
      var nodes = document.getElementsByClassName("boxItemStyle")
      setTimeout(() => {
        //var node1 = Array.from(nodes)
       // var node2 = Array.prototype.slice.call(nodes)
        for (var i = 0; i < nodes.length; i++) {
          nodes[i].style.width = itemWidth + "px"
          if (i < columns) {
            nodes[i].style.width = itemWidth + "px"
            nodes[i].style.left = itemWidth * i + i * 50 + "px"
            nodes[i].style.top = 0
            arr.push(nodes[i].offsetHeight);
          } else {
            // Find the minimum height in the array and its index var minHeight = arr[0];
            var index = 0;
            for (var j = 0; j < arr.length; j++) {
              if (minHeight > arr[j]) {
                minHeight = arr[j];
                index = j;
              }
            }
            nodes[i].style.top = arr[index] + 30 + "px",
              nodes[i].style.left = nodes[index].offsetLeft + 'px';
            // Modify the height of the minimum column // The height of the minimum column = the current height + the height of the spliced ​​column arr[index] = arr[index] + nodes[i].offsetHeight + 30; // Set a distance of 30 }
        }
      }, 1000)
    },

Dynamically loading data

onScrollEvent () {
      if (
        this.isScroll &&
        this.$refs.box.scrollHeight - this.$refs.box.scrollTop - this.$refs.box.clientHeight <= 0
      ) {
        this.loading = true
        if (this.ipagination.current == 1) {
          this.ipagination.current += 1
        }
        let param = {}
        param['pageNo'] = this.ipagination.current
        param['pageSize'] = this.ipagination.pageSize
        param['portraitId'] = this.portraitId
        postAction(this.url.list, { ...param }).then((res) => {
          this.loading = false
          if (res.success) {
            this.isScroll = res.records
            this.dataSource = this.dataSource.concat(res.result.records || res.result)
            this.waterFall();
          }
        })
        this.ipagination.current++
      }
    },

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • JS realizes the effect of picture waterfall flow
  • Using js to achieve waterfall effect
  • How to use JS to implement waterfall layout of web pages
  • js to achieve waterfall flow layout (infinite loading)
  • 3 ways to implement waterfall layout with JavaScript
  • Have you learned how to implement JavaScript waterfall flow?

<<:  How to find and delete duplicate records in MySQL

>>:  Problems and solutions for installing Docker on Alibaba Cloud

Recommend

Vue implements video upload function

This article example shares the specific code of ...

Summary of the differences between Mysql primary key and unique key

What is a primary key? A primary key is a column ...

7 useful new TypeScript features

Table of contents 1. Optional Chaining 2. Null va...

How to quickly log in to MySQL database without password under Shell

background When we want to log in to the MySQL da...

VMware Workstation 15 Pro Installation Guide (for Beginners)

01. VMware Workstation Pro 15 Download Download: ...

Install mysql5.7.13 using RPM in CentOS 7

0. Environment Operating system for this article:...

36 principles of MySQL database development (summary)

Preface These principles are summarized from actu...

Detailed explanation of the life cycle of Angular components (Part 2)

Table of contents 1. View hook 1. Things to note ...

Detailed graphic explanation of how to use svg in vue3+vite project

Today, in the practice of vue3+vite project, when...

How to improve Idea startup speed and solve Tomcat log garbled characters

Table of contents Preface Idea startup speed Tomc...

How to change $ to # in Linux

In this system, the # sign represents the root us...

Summarize the common application problems of XHTML code

Over a period of time, I found that many people d...