Example code for element multiple tables to achieve synchronous scrolling

Example code for element multiple tables to achieve synchronous scrolling

Element UI implements multiple tables scrolling at the same time, horizontally and vertically

insert image description here

The code is as follows:

<script src="//unpkg.com/vue/dist/vue.js"></script>
<script src="//unpkg.com/[email protected]/lib/index.js"></script>
<div id="app">
<template>
    <el-table
      ref="table1"
      border="10"
      height="150"
      :data="tableData"
      style="width: 800px">
      <el-table-column
        prop="date"
        label="Date"
        width="300">
      </el-table-column>
      <el-table-column
        prop="name"
        label="Name"
        width="300">
      </el-table-column>
      <el-table-column
        width="300px"
        prop="address"
        label="Address">
      </el-table-column>
            <el-table-column
        width="300px"
        prop="address"
        label="Address">
      </el-table-column>
    </el-table>
    <br/>
    <el-table
      ref="table2"
      border="10"
      height="150"
      :data="tableData"
      style="width: 800px">
      <el-table-column
        prop="date"
        label="Date"
        width="300">
      </el-table-column>
      <el-table-column
        prop="name"
        label="Name"
        width="300">
      </el-table-column>
      <el-table-column
        width="300px"
        prop="address"
        label="Address">
      </el-table-column>
            <el-table-column
        width="300px"
        prop="address"
        label="Address">
      </el-table-column>
    </el-table>
  </template>
</div>
var Main = {
      data() {
        return {
          tableData: [{
            date: '2016-05-02',
            name: 'Wang Xiaohu',
            address: 'Shanghai'
          }, {
            date: '2016-05-04',
            name: 'Wang Xiaohu',
            address: 'Shanghai'
          }, {
            date: '2016-05-04',
            name: 'Wang Xiaohu',
            address: 'Shanghai'
          }, {
            date: '2016-05-04',
            name: 'Wang Xiaohu',
            address: 'Shanghai'
          }],
          dom1: null,
          dom2: null
        }
      },
      mounted() {
        this.dom1 = this.$refs.table1.bodyWrapper
        this.dom2 = this.$refs.table2.bodyWrapper

        this.listenerScroll()
      },
      methods: {
        listenerScroll() {
          this.dom2.addEventListener('scroll', () => {
            // Scroll this.dom1.scrollLeft = this.dom2.scrollLeft
            // Vertical scroll this.dom1.scrollTop = this.dom2.scrollTop
          })
        }
      }
    }
var Ctor = Vue.extend(Main)
new Ctor().$mount('#app')

This is the end of this article about how to achieve synchronized scrolling of multiple element tables. For more information about synchronized scrolling of element tables, please search previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Solve the problem of hiding table columns in element-ui
  • Detailed explanation of the writing method of VUE2.0+ElementUI2.0 table el-table loop dynamic column rendering
  • The cool operations on table in Element-UI (summary)
  • Solution to Table Problem in ElementUI
  • 4 ways to modify Element's el-table style in Vue
  • Detailed explanation of table column timestamp formatting in Element UI of vue2.0
  • Using the slot-scope method of Element UI Table

<<:  Detailed explanation of the Docker deployment tutorial for Jenkins beginners

>>:  Explanation of the execution priority of mySQL keywords

Recommend

Demystifying the HTML 5 Working Draft

The World Wide Web Consortium (W3C) has released a...

Summary of Docker Data Storage

Before reading this article, I hope you have a ba...

Nginx Linux installation and deployment detailed tutorial

1. Introduction to Nginx Nginx is a web server th...

Detailed explanation of destructuring assignment syntax in Javascript

Preface The "destructuring assignment syntax...

JavaScript explains the encapsulation and use of slow-motion animation

Implementing process analysis (1) How to call rep...

The difference between br and br/ in HTML

answer from stackflow: Simply <br> is suffic...

In-depth understanding of the vertical-align property and baseline issues in CSS

vertical-align attribute is mainly used to change...

Introduction to the use of CSS3 filter attribute

1. Introduction When writing animation effects fo...

HTML Tutorial: Collection of commonly used HTML tags (4)

Related articles: Beginners learn some HTML tags ...

Three methods of automatically completing commands in MySQL database

Note: The third method is only used in XSell and ...

React and Redux array processing explanation

This article will introduce some commonly used ar...

This article teaches you how to play with CSS border

Border Style The border-style property specifies ...