element ui table实现前端分页 及 选择相关

 

 如上图,实现红框里的功能

<template>
  <div class="hello">
    <p class="title">
      <span>已选择{{multipleSelection.length}}条</span>
      <el-button @click="clearDate">清空</el-button>
    </p>
    <el-table
      ref="multipleTable"
      :data="tableData3.slice((currentPage-1)*pageSize,currentPage*pageSize)"
      tooltip-effect="dark"
      style="width: 100%"
      @selection-change="handleSelectionChange"
      @select="selectChange"
      @select-all="selectAll"
      >
      <el-table-column
        type="selection"
        width="55"
        :reserve-selection="true">
      </el-table-column>
      <el-table-column
        prop="date"
        label="日期"
        width="120">
        <template slot-scope="scope">{{ scope.row.date }}</template>
      </el-table-column>
      <el-table-column
        prop="name"
        label="姓名"
        width="120">
      </el-table-column>
      <el-table-column
        prop="address"
        label="地址"
        show-overflow-tooltip>
      </el-table-column>
    </el-table>
    <el-pagination
      background
      :page-size="pageSize"
      :current-page="currentPage"
      @current-change="handleCurrentChang"
      layout="prev, pager, next, total"
      :total="tableData3.length">
    </el-pagination>
    <div style="text-align:left">
      <span style="margin-right:20px">已选择{{multipleSelection.length}}</span>
      <el-checkbox-group v-model="selectNum" :min="0" :max="1" @change="handleCheckmount(multipleSelection)">
        <el-checkbox v-for="item in optionsItem" :label="item" :key="item">{{item}}</el-checkbox>
      </el-checkbox-group>
    </div>
  </div>
</template>

<script>
const optionsItem = ['50', '100']
export default {
  data () {
    return {
      tableData3: [
        {
          date: '2016-05-03',
          name: '1王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-02',
          name: '2王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-04',
          name: '3王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-01',
          name: '4王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-08',
          name: '5王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-06',
          name: '6王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '7王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '8王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '9王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '10王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '11王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '12王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '13王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '14王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          date: '2016-05-07',
          name: '15王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        }
      ],
      multipleSelection: [],
      currentPage: 1,
      pageSize: 5,
      checkedNum: [],
      optionsItem: optionsItem,
      selectNum: [],
      num: 0
    }
  },

  methods: {
    // 清除
    clearDate () {
      this.$refs.multipleTable.clearSelection()
      this.multipleSelection = []
      this.selectNum = []
    },
    // 选择条数
    handleCheckmount (rows) {
      this.num = this.selectNum[0]
      if (this.num) {
        this.multipleSelection = this.tableData3.slice(0, this.num)
        this.multipleSelection.forEach(row => {
          this.$refs.multipleTable.toggleRowSelection(row, true)
        })
      } else {
        this.$refs.multipleTable.clearSelection()
      }
    },
    // 全选
    selectAll (selection) {
      // console.log(selection)
      this.multipleSelection = selection
      console.log(this.multipleSelection)
      this.selectNum = []
    },
    handleSelectionChange (val) {
      this.multipleSelection = val
    },
    // 手动选择
    selectChange (selection, rows) {
      this.selectNum = []
    },
    // 分页
    handleCurrentChang (currentPage) {
      this.currentPage = currentPage
    }
  }
}
</script>

<style>
  .title{
    text-align:center
  }
  .el-checkbox-group{
    display: inline-block;
  }
  .el-checkbox__label{
    padding-left: 0px;
  }
</style>
posted @ 2019-09-05 10:38  adongP  阅读(2065)  评论(0编辑  收藏  举报